10.1. SqlSugar 集成
温馨提醒
在 Furion
包中默认集成了 EFCore
,如果不使用 EFCore
,可安装纯净版 Furion.Pure
代替 Furion
,这样可以忽略本章节直接按照 SqlSugar
官方文档使用。
10.1.1 关于 SqlSugar
SqlSugar
是 .NET/C# 平台非常优秀的 ORM
框架,目前 NuGet
总下载突破 700K,Github 关注量也高达 3.2K,是目前当之无愧的国产优秀 ORM 框架之一。
SqlSugar
官方地址:http://www.donet5.com/
SqlSugar
与 EF 优势: 性能比 EF 更快、语法上手更容易
SqlSugar
与 Dapper 优势: SqlSugar 功能更加丰富,性能丝毫不逊色于 Dapper,并且批量操作性能更好
10.1.2 如何集成
在 Furion
框架中,已经推出 SqlSugar
拓展包 Furion.Extras.DatabaseAccessor.SqlSugar。
10.1.2.1 注册 SqlSugar
服务
使用非常简单,只需要在 Startup.cs
中添加 services.AddSqlSugar(config)
即可。如:
// =====配置单库=====
services.AddSqlSugar(new ConnectionConfig
{
ConnectionString = "Server=.xxxxx",//连接符字串
DbType = DbType.SqlServer,
IsAutoCloseConnection = true,
InitKeyType = InitKeyType.Attribute//从特性读取主键自增信息
});
// =====配置多库=====
List<ConnectionConfig> connectConfigList = new List<ConnectionConfig>();
//数据库1
connectConfigList.Add(new ConnectionConfig
{
ConnectionString = "链接字符串1",
DbType = DbType.MySql,
IsAutoCloseConnection = true,
InitKeyType = InitKeyType.Attribute,
ConfigId = "0",
AopEvents = new AopEvents
{
//多库状态下每个库必须单独绑定打印事件,否则只会打印第一个库的sql日志
OnLogExecuting = (sql, pars) =>
{
Console.WriteLine(SqlProfiler.ParameterFormat(sql, pars));
Console.WriteLine();
}
}
});
//数据库2
connectConfigList.Add(new ConnectionConfig
{
ConnectionString = "链接字符串2",
DbType = DbType.MySql,
IsAutoCloseConnection = true,
InitKeyType = InitKeyType.Attribute,
ConfigId = "1",
AopEvents = new AopEvents
{
//多库状态下每个库必须单独绑定打印事件,否则只会打印第一个库的sql日志
OnLogExecuting = (sql, pars) =>
{
Console.WriteLine(SqlProfiler.ParameterFormat(sql, pars));
Console.WriteLine();
}
}
});
services.AddSqlSugar(connectConfigList.ToArray());
同时也可以添加更多配置,如: ps:多库状态下每个库必须单独绑定打印事件,否则只会打印第一个库的 sql 日志(参考上面的多库配置)
services.AddSqlSugar(connectConfigList.ToArray(),
db =>
{
//处理日志事务
db.Aop.OnLogExecuting = (sql, pars) =>
{
Console.WriteLine(sql);
Console.WriteLine(string.Join(",", pars?.Select(it => it.ParameterName + ":" + it.Value)));
Console.WriteLine();
App.PrintToMiniProfiler("SqlSugar", "Info", sql + "\r\n" + db.Utilities.SerializeObject(pars.ToDictionary(it => it.ParameterName, it => it.Value)));
};
});
安装拓展包位置
在 Furion
框架中,推荐将拓展包 Furion.Extras.DatabaseAccessor.SqlSugar
安装到 Furion.Core
层中。
10.1.3 基本使用
在使用之前,我们可以通过构造函数注入 ISqlSugarRepository
接口,如:
private readonly ISqlSugarRepository repository; // 仓储对象:封装简单的CRUD
private readonly SqlSugarClient db; // 核心对象:拥有完整的SqlSugar全部功能
public PersonService(ISqlSugarRepository sqlSugarRepository)
{
repository = sqlSugarRepository;
db = repository.Context; // 推荐操作
}
10.1.4 数据库操作示例
// ================== SqlSugarClient ================
//查询功能
var data1 =db.Queryable<Student>().First(it=>it.Id==1); //db.GetById(1);
var data2 = db.Queryable<Student>().ToList();// db.GetList();
// ================== 简单仓储 ================
//插入
db.Insert(insertObj);
var id = db.InsertReturnIdentity(insertObj);
db.AsInsertable(insertObj).ExecuteCommand();
//删除
db.Delete(insertObj);
db.Delete(it => it.Id == 1);
//更新
db.Update(insertObj);
db.Update(it => new Order() { Name = "a", }, it => it.Id == 1);
//异步方法用法
db.Insert(insertObj);//同步
db.InsertAsync(insertObj);//异步
//切换仓储
var orderRespository=db.GetSimpleClient<Order>();
orderRespository.Insert(Order);
10.1.5 SqlSugarClient 操作示例
10.1.5.1 基础查询
//查询所有
var getAll = db.Queryable<Student>().ToList();
//查询前10
var top10= db.Queryable<Student>().Take(10).ToList();
//查询单条
var getFirst = db.Queryable<Student>().First(it=>it.Id==1);
//with nolock
var getAllNoLock = db.Queryable<Student>().With(SqlWith.NoLock).ToList();
//根据主键查询
var getByPrimaryKey = db.Queryable<Student>().InSingle(2);
//查询总和
var sum = db.Queryable<Student>().Sum(it=>it.Id);
//是否存在
var isAny = db.Queryable<Student>().Where(it=>it.Id==-1).Any();
//模糊查
var list2 = db.Queryable<Order>().Where(it =>it.Name.Contains("jack")).ToList();
10.1.5.2 联表查询
var list = db.Queryable<Student, School>((st, sc) => new JoinQueryInfos(
JoinType.Left,st.SchoolId==sc.Id))
.Select((st,sc)=>new{Id=st.Id,Name=st.Name,SchoolName=sc.Name}).ToList();
生成的Sql如下:
SELECT [st].[ID] AS [id] ,
[st].[Name] AS [name] ,
[sc].[Name] AS [schoolName] FROM [STudent] st
Left JOIN School sc ON ( [st].[SchoolId] =[sc].[Id])