ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

C# SqlSugar框架的学习使用(一)--SqlSugar简介及创建

2022-01-10 09:32:55  阅读:484  来源: 互联网

标签:C# db 查询 -- var com Queryable SqlSugar


C# SqlSugar框架的学习使用(一)--SqlSugar简介及创建

SqlSugar介绍

SqlSugar ORM,NET 4.+ & .NET CORE 高性能轻量级ORM框架,众多.NET框架中最容易使用的数据库访问技术。

主页:http://www.codeisbug.com/

下载地址:https://github.com/sunkaixuan/SqlSugar

当然也可以直接用Nuget安装,非常方便。

 

SqlSugar的16大功能

 

SqlSugar查询特色

 

SqlSugar的优点

  • 高性能 ,不夸张的说,去掉Sql在数据库执行的时间,SqlSugar是EF数倍性能,另外在批量操作和一对多查询上也有不错的SQL优化

  • 高扩展性 ,支持自定义拉姆达函数解析、扩展数据类型、支持自定义实体特性,外部缓存等

  • 稳定性和技术支持,  虽然不是官方ORM, 但在稳定性上也是有着数年用户积累,如果遇到问题可以在GITHUB提出来,会根据紧急度定期解决

  • 功能全面,虽然SqlSugar小巧可功能并不逊色于EF框架

  • 创新、持续更新 ,向下兼容

 

SqlSugar项目创建

我们打开VS2017,新建一个C#的桌面应用程序,起名为SqlSugarTest

 

然后鼠标右键选择引用,选择管理NuGet程序包

 

然后点击浏览后输入sqlsugar查找,找到的第一个就是直接点击安装

 

安装完后点击已安装,并且点开右边的引用后也可以看到SqlSugar就已经安装好了,如下图

 

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();

 

实体类用法

//如果实体类名称和表名不一致可以加上SugarTable特性指定表名[SugarTable("Student")]public class StudentModel{    //指定主键和自增列,当然数据库中也要设置主键和自增列才会有效    [SugarColumn(IsPrimaryKey=true,IsIdentity =true)]    public int Id { get; set; }    public string Name { get; set; }}

 

根据实体类创建表

 

db.CodeFirst.SetStringDefaultLength(200/*设置varchar默认长度为200*/).InitTables(typeof(StudentModel));//执行完数据库就有这个表了

 

总结:

SqlSugar是通过Queryable、Updateable、Deleteable和Insertable实现的增删改查。

标签:C#,db,查询,--,var,com,Queryable,SqlSugar
来源: https://www.cnblogs.com/zkwarrior/p/15783116.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有