ABP引入SqlSugar框架创建使用的方法
发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,这篇文章主要介绍了ABP引入SqlSugar框架创建使用的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇ABP引入SqlSugar框架创建使用的方法文章都会有所收获,
千家信息网最后更新 2025年11月09日ABP引入SqlSugar框架创建使用的方法
这篇文章主要介绍了ABP引入SqlSugar框架创建使用的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇ABP引入SqlSugar框架创建使用的方法文章都会有所收获,下面我们一起来看看吧。
一 新建类库
为了代码清晰,我新建了一个类库。引入了SqlSugar的框架包,2个仓储类,1个DbContext
声明实体
[SugarTable("BasBloodLevel")] public class BasBloodLevel { [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] public int Id { get; set; } public string Code { get; set; } }二 基本仓储
先实现基本仓储IBaseRepository 与 BaseRepository
////// 基类接口,其他接口继承该接口 /// ///public interface IBaseRepository where TEntity : class { /// /// 根据ID查询 /// /// ///Task QueryByID(object objId); /// /// 添加 /// /// ///Task Add(TEntity model); /// /// 修改 /// /// ///Task Update(TEntity model); /// /// 删除 /// /// ///Task DeleteByIds(object[] ids); }
////// 基类实现 /// ///public class BaseRepository : DbContext , IBaseRepository where TEntity : class, new() { /// /// 写入实体数据 /// /// ///public async Task Add(TEntity model) { //这里需要注意的是,如果使用了Task.Run()就会导致 sql语句日志无法记录改成下面的 //var i = await Task.Run(() => Db.Insertable(model).ExecuteCommand()); var i = await Db.Insertable(model).ExecuteCommandAsync(); return i > 0; } /// /// 根据ID删除 /// /// ///public async Task DeleteByIds(object[] ids) { var i = await Db.Deleteable ().In(ids).ExecuteCommandAsync(); return i > 0; } /// /// 根据ID查询一条数据 /// /// ///public async Task QueryByID(object objId) { return await Db.Queryable ().InSingleAsync(objId); } /// /// 更新实体数据 /// /// ///public async Task Update(TEntity model) { //这种方式会以主键为条件 var i = await Db.Updateable(model).ExecuteCommandAsync(); return i > 0; } }
三 实现SqlSugar的DB
此处的 ConnectionString 地址,我们可以直接读取 ABP框架的配置文件,但是为了方便我直接写死了
public class DbContextwhere T : class, new() { public DbContext() { Db = new SqlSugarClient(new ConnectionConfig() {//数据库地址我们可以直接读取 ABP框架的配置文件,但是为了方便我直接写死了 ConnectionString = "Server=****; Database=****; Uid=sa; Pwd=****;MultipleActiveResultSets=true;", DbType = DbType.SqlServer, InitKeyType = InitKeyType.Attribute,//从特性读取主键和自增列信息 IsAutoCloseConnection = true,//开启自动释放模式 }); //调式代码 用来打印SQL Db.Aop.OnLogExecuting = (sql, pars) => { Console.WriteLine(sql + "\r\n" + Db.Utilities.SerializeObject(pars.ToDictionary(it => it.ParameterName, it => it.Value))); Console.WriteLine(); }; } //注意:不能写成静态的 public SqlSugarClient Db;//用来处理事务多表查询和复杂的操作 public SimpleClient CurrentDb { get { return new SimpleClient (Db); } }//用来操作当前表的数据 public SimpleClient BasBloodLevelDb { get { return new SimpleClient (Db); } }//用来处理User表的常用操作 }
四 实现依赖注入
这样我们就能全局使用了
[DependsOn(typeof(AbpZeroCoreModule))] public class Module : AbpModule { public override void Initialize() { IocManager.Register(typeof(IBaseRepository<>), typeof(BaseRepository<>), DependencyLifeStyle.Singleton); //依赖注入程序集 IocManager.RegisterAssemblyByConvention(typeof(Module).GetAssembly()); } }既然要实现依赖注入,那肯定要初始化这个类触发注入了。我选择在EF层里加,这样可以不影响原有的EF层初始化
五 应用层使用
直接引用对应的 IBaseRepository仓储
public class BasBloodBreedAppService : BloodTestLibSystemAppServiceBase,IApplicationService { private IBaseRepository _baseRepository { get; set; } public BasBloodBreedAppService(IBaseRepository baseRepository) { _baseRepository = baseRepository; } public async Task GetBase() { var ce=await _baseRepository.QueryByID(1); return ce; } } 证明一下我是成功的
关于"ABP引入SqlSugar框架创建使用的方法"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"ABP引入SqlSugar框架创建使用的方法"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。
框架
数据
方法
仓储
实体
接口
知识
查询
代码
内容
地址
文件
篇文章
处理
配置
复杂
成功
事务
价值
信息
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全产品的内涵
软件开发合同的知识产权约定
90年代互联网科技公司
生活中影响数据库安全性事例
教育工作者与网络安全
网络安全哪年
组态王串口服务器模板
电脑命令控制打开数据库
对日软件开发计划管理
自贡 软件开发 招聘
遇朔网络技术有限公司
学术类网络数据库
网络技术新媒体环境历史
网络安全知识别上当
地铁逃生哪个服务器的人少
2022年tbc服务器
找不到u8管理服务器
软件开发标准化的核心
自考数据库技术
sc原油数据库
熊片数据库系统
河南量化积分管理软件开发
安卓视频播放软件开发
甘南国家网络安全宣传
邢台网络技术怎么样
零基础适合软件开发吗
谷歌云服务器大约多少台
乡网络安全自查 情况汇报
数据库加索引mysql
济南金税盘安全接入服务器地址