当前位置:首页 > 技术分析 > 正文内容

.Net6基础功能封装分享7(ORM框架Sqlsugar集成)

ruisui883个月前 (02-03)技术分析20

在.netcore中有很多优秀的ORM开源框架,我选择了集成Sqlsugar,Sqlsugar的优点很多,我就不在这里详述了,最让我中意的还是Sqlsugar在文档方面我觉得是做的最好的,必须给作者点赞。

首先当然还是下载SqlSugarCore依赖包啦

然后编写数据源配置对象和在配置文件中增加配置

编写增加sqlSugar的扩展方法(获取配置源、创建创建sqlclient对象、增加sql语句执行日志拦截器、sql异常拦截器、插入和更新拦截器、将SqlSugarClient对象以单例模式注入到IServiceCollection容器中、启动连接验证等)

public static IServiceCollection AddDataSource(this IServiceCollection services, IConfiguration configuration)
{
    //获取数据源配置
    DataSourceConfig dataSource = configuration.GetT();
    DbContext.SetDataSourceConfig(dataSource);
    if (dataSource == null)
    {
        NLogger.Default.Error("获取数据库连接配置错误");
        return services;
    }
    DbType dbType = (DbType)Enum.Parse(typeof(DbType), dataSource.DbType);
    //创建SqlSugarClient对象
    SqlSugarScope sqlSugar = new SqlSugarScope(new ConnectionConfig()
    {
        ConfigId= "default",
        DbType = dbType,
        IsAutoCloseConnection = true,
        ConnectionString = dataSource.ConnectionString,
    },
     db =>
     {
        //增加sql语句执行日志
         db.Aop.OnLogExecuting = (sqlStr, pms) =>
         {
             if (dataSource.IsPrintSqlLog)
             {
                 NLogger.Default.Info($"执行sql语句:{UtilMethods.GetNativeSql(sqlStr, pms)}");
             }
         };
         //异常
         db.Aop.OnError = (ex) =>
         {
             NLogger.Default.Error("==============执行sql错误==============");
             if (ex.Parametres == null)
             {
                 NLogger.Default.Error(ex.Sql);
             }
             else
             {
                 SugarParameter[] param = ex.Parametres as SugarParameter[];
                 NLogger.Default.Error(UtilMethods.GetNativeSql(ex.Sql, param));
             }
         };
         //插入和更新过滤器
         db.Aop.DataExecuting = (oldValue, entityInfo) =>
         {
             // 新增操作
             if (entityInfo.OperationType == DataFilterType.InsertByObject)
             {
                 // 主键(long类型)且没有值的---赋值雪花Id
                 if (entityInfo.EntityColumnInfo.IsPrimarykey && entityInfo.EntityColumnInfo.PropertyInfo.PropertyType == typeof(long))
                 {
                     var id = entityInfo.EntityColumnInfo.PropertyInfo.GetValue(entityInfo.EntityValue);
                     if (id == null || (long)id == 0)
                     {
                         entityInfo.SetValue(CommonUtils.GetSingleId());
                     }
                 }
                 if (entityInfo.PropertyName == nameof(BaseEntity.CreateTime))
                 {
                     entityInfo.SetValue(DateTime.Now);
                 }
                 //if (App.User != null)
                 //{
                 //    //创建人和创建机构ID
                 //    if (entityInfo.PropertyName == nameof(BaseEntity.CreateUserId))
                 //    {
                 //        entityInfo.SetValue(App.User.FindFirst(ClaimConst.UserId)?.Value);
                 //    }
                 //    if (entityInfo.PropertyName == nameof(BaseEntity.CreateUser))
                 //    {
                 //        entityInfo.SetValue(App.User?.FindFirst(ClaimConst.Account)?.Value);
                 //    }
                 //    if (entityInfo.PropertyName == nameof(DataEntityBase.CreateOrgId))
                 //    {
                 //        entityInfo.SetValue(App.User.FindFirst(ClaimConst.OrgId)?.Value);
                 //    }
                 //}
             }
             // 更新操作
             if (entityInfo.OperationType == DataFilterType.UpdateByObject)
             {
                 //更新时间
                 if (entityInfo.PropertyName == nameof(BaseEntity.UpdateTime))
                 {
                     entityInfo.SetValue(DateTime.Now);
                 }
                 //更新人
                 //if (App.User != null)
                 //{
                 //    if (entityInfo.PropertyName == nameof(BaseEntity.UpdateUserId))
                 //    {
                 //        entityInfo.SetValue(App.User?.FindFirst(ClaimConst.UserId)?.Value);
                 //    }
                 //    if (entityInfo.PropertyName == nameof(BaseEntity.UpdateUser))
                 //    {
                 //        entityInfo.SetValue(App.User?.FindFirst(ClaimConst.Account)?.Value);
                 //    }
                 //}

             }
         };
     });
    services.AddSingleton(sqlSugar);//这边是SqlSugarScope用AddSingleton
    DbContext.SetClient(sqlSugar);
    Task.Run(() =>
    {
        bool success = sqlSugar.Ado.IsValidConnection();
        if (success)
        {
            NLogger.Default.Info("[数据库连接测试]:数据库连接成功");
        }
        else
        {
            NLogger.Default.Error("[数据库连接测试]:数据库连接失败");
        }
    });
    return services;
}

在Program启动类中,执行增加数据源的扩展方法

为了业务中操作方便和符合自己的使用习惯,使用了仓储模式,编写仓储类,继承SimpleClient,可以自己增加共用的仓储扩展方法

在业务的数据访问层中创建dao对象,继承仓储类,就能使用sqlSugar中提供的方法,操作数据库表了,在Dao类中也有三种方式使用ISqlSugarClient对象

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/1331.html

分享给朋友:

“.Net6基础功能封装分享7(ORM框架Sqlsugar集成)” 的相关文章

「Git迁移」三行命令迁移Git包含提交历史,分支,tag标签等信息

问题描述:公司需要将一个git远程服务器的全部已有项目迁移到一台新服务器的Gitlab中,其中需要包含全部的提交纪录,已有的全部分支与全部打tag标签,目前此工作已全部迁移完毕,特此记录一下操作步骤环境描述:1. 要迁移的远程Git:Gitblit2. 迁移目的Git:Gitlab3. 暂存代码的P...

代码分支规范

一.gitflow工作流说明:主分支:master,稳定版本代码分支,对外可以随时编译发布的分支,不允许直接Push代码,只能请求合并(pull request),且只接受hotfix、release分支的代码合并。gitlab上做限制。热修复分支:hotfix,针对现场紧急问题、bug修复的代码分...

K8s里我的容器到底用了多少内存?

作者:frostchen导语 Linux下开发者习惯在物理机或者虚拟机环境下使用top和free等命令查看机器和进程的内存使用量,近年来越来越多的应用服务完成了微服务容器化改造,过去查看、监控和定位内存使用量的方法似乎时常不太奏效。如果你的应用程序刚刚迁移到K8s中,经常被诸如以下问题所困扰:容器的...

抖音 Android 性能优化系列:启动优化实践

启动性能是 APP 使用体验的门面,启动过程耗时较长很可能使用户削减使用 APP 的兴趣,抖音通过对启动性能做劣化实验也验证了其对于业务指标有显著影响。抖音有数亿的日活,启动耗时几百毫秒的增长就可能带来成千上万用户的留存缩减,因此,启动性能的优化成为了抖音 Android 基础技术团队在体验优化方向...

HTML5学习笔记三:HTML5语法规则

1.标签要小写2.属性值可加可不加””或”3.可以省略某些标签 html body head tbody4.可以省略某些结束标签 tr td li例:显示效果:5.单标签不用加结束标签img input6.废除的标签font center big7.新添加的标签将在下一HTML5学习笔记中重点阐述。...

全新斯柯达柯珞克Karoq深度评测:大众替代品

“斯柯达柯珞克是一款出色的全能家庭 SUV,具有许多有用的功能”价格36,605 英镑- 49,190 英镑优点方便的 VarioFlex 后排座椅非常适合家庭入住驾驶乐趣缺点保修期短保守的内饰性格比Yeti少结论——斯柯达柯珞克是一辆好车吗?斯柯达柯珞克是在辉煌的七座 斯柯达柯迪亚克之后推出的,因...