MySql 数据库访问框架_SqlSugar
目录相关连接:SqlSugar 介绍:SqlSugar的优点SqlSugar安装 使用:轻松学会增、删、改和查相关连接:作者主页:http://www.codeisbug.com用前必看:http://www.codeisbug.com/Doc/8教程地址:https://cloud.tencent.com/developer/article/1479554...
·
目录
相关连接:
- 作者主页:http://www.codeisbug.com
- 用前必看:http://www.codeisbug.com/Doc/8
- 教程地址:https://cloud.tencent.com/developer/article/1479554
SqlSugar 介绍:
SqlSugar ORM,NET 4.+ & .NET CORE 高性能轻量级ORM框架,众多.NET框架中最容易使用的数据库访问技术。
主页:http://www.codeisbug.com/
下载地址:https://github.com/sunkaixuan/SqlSugar
当然也可以直接用Nuget安装,非常方便。
SqlSugar的优点
- 高性能 ,不夸张的说,去掉Sql在数据库执行的时间,SqlSugar是EF数倍性能,另外在批量操作和一对多查询上也有不错的SQL优化
- 高扩展性 ,支持自定义拉姆达函数解析、扩展数据类型、支持自定义实体特性,外部缓存等
- 稳定性和技术支持, 虽然不是官方ORM, 但在稳定性上也是有着数年用户积累,如果遇到问题可以在GITHUB提出来,会根据紧急度定期解决
- 功能全面,虽然SqlSugar小巧可功能并不逊色于EF框架
- 创新、持续更新 ,向下兼容
SqlSugar安装 使用:
1.然后鼠标右键选择引用,选择管理NuGet程序包
2.然后点击浏览后输入sqlsugar查找,找到的第一个就是直接点击安装
3.安装完后点击已安装,并且点开右边的引用后也可以看到SqlSugar就已经安装好了,如下图
轻松学会增、删、改和查
SqlSugarClient db = new SqlSugarClient(
new ConnectionConfig()
{
ConnectionString = "server=.;uid=sa;pwd=@jhl85661501;database=SqlSugar4XTest",
DbType = DbType.SqlServer,//设置数据库类型
IsAutoCloseConnection = true,//自动释放数据务,如果存在事务,在事务结束后释放
InitKeyType = InitKeyType.Attribute //从实体特性中读取主键自增列信息
});
//用来打印Sql方便你调式
db.Aop.OnLogExecuting = (sql, pars) =>
{
Console.WriteLine(sql + "\r\n" +
db.Utilities.SerializeObject(pars.ToDictionary(it => it.ParameterName, it => it.Value)));
Console.WriteLine();
};
/*查询*/
var list = db.Queryable<StudentModel>().ToList();//查询所有
var getById = db.Queryable<StudentModel>().InSingle(1);//根据主键查询
var getByWhere = db.Queryable<StudentModel>().Where(it=>it.Id==1).ToList();//根据条件查询
var total = 0;
var getPage = db.Queryable<StudentModel>().Where(it => it.Id == 1).ToPageList(1,2,ref total);//根据分页查询
//多表查询用法 http://www.codeisbug.com/Doc/8/1124
/*插入*/
var data = new Student() { Name = "jack" };
db.Insertable(data).ExecuteCommand();
//更多插入用法 http://www.codeisbug.com/Doc/8/1130
/*更新*/
var data2 = new Student() { Id =1, Name = "jack" };
db.Updateable(data2).ExecuteCommand();
//更多更新用法 http://www.codeisbug.com/Doc/8/1129
/*删除*/
db.Deleteable<StudentModel>(1).ExecuteCommand();
//更多删除用法 http://www.codeisbug.com/Doc/8/1128
实体类
//如果实体类名称和表名不一致可以加上SugarTable特性指定表名
[SugarTable("Student")]
public class StudentModel
{
//指定主键和自增列,当然数据库中也要设置主键和自增列才会有效
[SugarColumn(IsPrimaryKey=true,IsIdentity =true)]
public int Id { get; set; }
public string Name { get; set; }
}
//当然也支持自定义特性, 这里就不细讲了
根据实体创建表
你可以根据现有实体去手动创建一个表,当然也可以用 SqlSugar提供的根据实体创建表功能
db.CodeFirst.SetStringDefaultLength(200/*设置varchar默认长度为200*/).InitTables(typeof(StudentModel));//执行完数据库就有这个表了
更多推荐
已为社区贡献1条内容
所有评论(0)