SqlSugar的Repository
1、仓储说明
仓储可以让你的方法更加的规范,需要什么方法都封装到仓储中,下次就能重复使用,并且能很好的和你业务拆分开
这种设计模式简单粗暴用起来也方便 ,文章下面有可以运行的DEMO
2、仓储方法
仓储有一套自带的数据库操作方法,比起 db.xx.xxx来说可能更简便些满足一些常用需求, 复杂的功能还是用db.xxx.xxx
//查询 var data1 = base .GetById(1); //根据id查询 var data2 = base .GetList(); //查询所有 (FindList) var data3 = base .GetList(it => it.Id == 1); //TOP1条件 var data4 = base .GetSingle(it => it.Id == 1); //查询单条记录,结果集不能超过1,不然会提示错误 var data= base .GetFirst(it => it.Id == 1); //查询第一条记录 var p = new PageModel() { PageIndex = 1, PageSize = 2 }; var data5 = base .GetPageList(it => it.Name == "xx" , p); Console.Write(p.PageCount); var data6 = base .GetPageList(it => it.Name == "xx" , p, it => it.Name, OrderByType.Asc); Console.Write(p.PageCount); List<IConditionalModel> conModels = new List<IConditionalModel>(); conModels.Add( new ConditionalModel(){FieldName= "id" ,ConditionalType=ConditionalType.Equal,FieldValue= "1" }); //id=1 var data7 = base .GetPageList(conModels, p, it => it.Name, OrderByType.Asc); var data8 = base .AsQueryable().Where(x => x.Id == 1).ToList(); //使用Queryable //插入 base .Insert(insertObj); base .InsertRange(InsertObjs); var id = base .InsertReturnIdentity(insertObj); //插入返回自增 var SnowflakeId= base .InsertReturnSnowflakeId(insertObj); //插入返回雪花ID base .AsInsertable(insertObj).ExecuteCommand(); //复杂功能使用Insertable //删除 base .Delete(T); //实体删除 需要有主键 base .Delete(List<T>); //集合删除 需要有主键 base .DeleteById(1); base .DeleteByIds( new object [] { 1, 2 }); //数组带是 ids方法 ,封装传 object [] 类型 //技巧 int [] 转换成 object[] 写法:ids.Cast<object>().ToArray() base .Delete(it => it.Id == 1); base .AsDeleteable().Where(it => it.Id == 1).ExecuteCommand(); //复杂功能用 Deleteable //实体方式更新更新 base .Update(insertObj); base .UpdateRange(InsertObjs); base .AsUpdateable(insertObj).UpdateColumns(it=> new { it.Name }).ExecuteCommand(); //复杂功能用 Updateable //表达式方式更新 base .Update(it => new Order() { Name = "a" /*可以多列*/ }, it => it.Id == 1); //只更新name 并且id=1 base .UpdateSetColumnsTrue(it=> new Order(){ Name = "a" }, it =>it.Id == 1); //更新name+过滤事件赋值字段 base .AsUpdateable().SetColumns(it=> new Order{ Name= "a" }) .Where(it=>it.Id==1).ExecuteCommand(); //复杂功能用 Updateable //高级操作 base .Context //获取db对象 base .AsSugarClient // 获取完整的db对象 base .AsTenant // 获取多库相关操作 //如果Context是子Db base .Context.Root //可以用Root拿主Db base .Context.Root.AsTenant() //拿到租户对象 //切换仓储 (可以注入多个仓储取代,这样就不用切换了) base .ChangeRepository<Repository<OrderItem>>() //多租户用法有区别:https://www.donet5.com/Home/Doc?typeId=2405 base .Change<OrderItem>() //只支持自带方法和单库 |
3、创建仓储
3.1 创建仓储
只需要几行代码就搞定了,我们定义的Repository是公用类,不能包含具体的类务逻辑,即使不使用扩展方法自带的方法也够开发
public class Repository<T> : SimpleClient<T> where T : class , new () { public Repository(ISqlSugarClient db) { base .Context=db; } /// <summary> /// 扩展方法,自带方法不能满足的时候可以添加新方法 /// </summary> /// <returns></returns> public List<T> CommQuery( string json) { //base.Context.Queryable<T>().ToList();可以拿到SqlSugarClient 做复杂操作 return null ; } } |
4、使用仓储
4.1 通过IOC使用仓储
//注入仓储 builder.Services.AddScoped( typeof (Repository<>)); //注入SqlSugar ...省略,不会看入门 //多个可以在构造函数写多个(用这种方式就不需要切换仓储了,有几个注入几个) public WeatherForecastController(Repository<Order> repOrder,Repository<Custom> repCustom) { _repOrder= repOrder; _repCustom=repCustom; } //使用注入的仓储 _repOrder.Insert(data); _repOrder.Context.Queryable<T>().ToList(); //.Context可以拿到db对象 //创建的仓储 public class Repository<T> : SimpleClient<T> where T : class , new () { public Repository(ISqlSugarClient db) //因为不需要切换仓储所以可以直接用构造函数获取db { base .Context=db; } } |
4.2 不用IOC使用仓储
//该用例建议升级5.1.3.35以上版本 public class UserService : IUserService, IDynamicApiController, ITransient //接口根据业务可以不需要 { //也可以用Ioc注入,不注入更方便些( ”=>" 表示用的时候才去new,不会在实例化类时候去new Repository<Abpusers> _userRepository => new Repository<Abpusers>(); //Repository不能单例 ISqlSugarClient _db=>_userRepository.Context; /// <summary> /// 获取用户列表 /// </summary> /// <returns></returns> public async Task<List<GetUserDto>> Get() { var users = await _userRepository.GetListAsync(); return users.Adapt<List<GetUserDto>>(); } } public class Repository<T> : SimpleClient<T> where T : class , new () { public Repository() { base .Context=DbHelper.GetDbInstance() } } |
注意:因为支持获取外部仓储,所以不需要像ABP那样构造函数写一堆
//获取外部仓储 var itemDal=_userRepository.ChangeRepository<Repository<OrderItem>>(); var orderDal=_userRepository.ChangeRepository<Repository<Order>>(); //base.Change<OrderItem>()这种写法与上面区别在于只能用ORM中的方法,没办法使用扩展类中的方法 |
DEMO下载: SqlSugarDemo.rar
4.3 db直接调用仓储
//使用ORM自带的仓储 var orderDal= db.GetSimpleClient<Order>(); //使用自定义的仓储 5.1.3.28-preview06 var orderDal=db.GetRepository<Repository<Order>>(); //3.1有介绍自定义仓储如创建 //使用仓储方法 orderDal.Insert(data); |
5、调用外部仓储
操作Order表的同时,我还想使用OrderItem这个仓储怎么办?
var orderItemDb = _userRepository.ChangeRepository<Repository<OrderItem>>(); public Repository(ISqlSugarClient db== null ) //这儿要改成可空 { base .Context=db; } //如果是多库模式需要注入,打开面页看标题4 //https://www.donet5.com/Home/Doc?typeId=2405 |
6、仓储中使用事务
注意: 如果是多租户事务写法有差异,看标题7
try { _userRepository.AsTenant().BeginTran(); //你的增查改方法 _userRepository.AsTenant().CommitTran(); } catch (Exception ex) { _userRepository.AsTenant().RollbackTran(); throw ; } |
注意: 如果是多租户事务写法有差异,看标题7
7、多租户使用仓储
因为要多个仓储用一个SqlSugarClient,我们需要用到Sugar.Ioc进行DB共享
https://www.donet5.com/Home/Doc?typeId=2405
SqlSugar的Repository的更多相关文章
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](四)
前言 上一篇<一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](三)>,我们完成了: * 引用SqlSugar * ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](三)
前言 上一篇<一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](二)>我们通过如下操作: 创建实体及工具类 创建Re ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](一)
前言 大家好,我是Rector 从今天开始,Rector将为大家推出一个关于创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar]的文章系列, ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](五)
前言 Hi,大家好,我是Rector 时间飞逝,一个星期又过去了,今天还是星期五,Rector在图享网继续跟大家分享系列文本:一步一步创建ASP.NET MVC5程序[Repository+Autof ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](二)
前言: 在本系列第一篇<一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](一)>中,我为大家介绍了搭建空白解决方案以 ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](六)
前言 大家好,我是Rector 又是星期五,很兴奋,很高兴,很high...啦啦啦... Rector在图享网又和大家见面啦!!!上一篇<一步一步创建ASP.NET MVC5程序[Reposit ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](七)
前言 大家好,我依旧是你们的老朋友Rector,很高兴又在周五的时候准时和大家见面. Rector的系列文章[一步一步创建ASP.NET MVC5程序[Repository+Autofac+Autom ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](八)
前言 Hi, 大家好,还是星期五,还是Rector,又在图享网准时和大家见面了. 今天给大家带来系列教程<一步一步创建ASP.NET MVC5程序[Repository+Autofac+Auto ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](九)
前言 童鞋们,大家好 我是专注.NET开发者社区建设的实践者Rector. 首先,为自己间隔了两个星期五再更新本系列文章找个不充分的理由:Rector最近工作,家庭的各种事务所致,希望大家谅解. 本文 ...
- 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](十)
前言 朋友们, 大家好,我还是Rector,写ASP.NET MVC 5系列文章[一步一步创建ASP.NET MVC5程序Repository+Autofac+Automapper+SqlSugar] ...
随机推荐
- Skywalking 8.1 Docker 服务端部署
前置条件 Docker 安装 Elasticsearch ### 部署服务端 skywalking-oap-server docker pull apache/skywalking-oap-serve ...
- 【django-vue】登录注册模态框分析 登录注册前端页面 腾讯短信功能二次封装 短信验证码接口 短信登录接口 短信注册接口
目录 昨日回顾 csrf跨站请求伪造 接口幂等性 异常捕获 今日内容 1 登录注册模态框分析 Login.vue Header.vue 2 登录注册前端页面复制 2.0 Header.vue 2.1 ...
- k8s-修改线程数
1.背景: (1)胖容器ssh登录报错:handshake error (2)登录宿主机后,观察pod状态为running,但是kubectl exec 和docker exec 均无法进入该容器,报 ...
- 【JAVA基础】批处理脚本
update ifp_project set is_self_run = 'N' where is_self_run is null; update ifp_invoice_header set is ...
- 「HDU-2196」Computer (树形DP、树的直径)
「HDU-2196」Computer 树形dp,树的最长路径(最远点对) 题意 给出一棵nn个结点的无根树,求出每个结点所能到达的最远点的距离. 解法 将无根树转成有根树,并进行两次DFS. 第一次D ...
- springboot启动流程 (3) 自动装配
在SpringBoot中,EnableAutoConfiguration注解用于开启自动装配功能. 本文将详细分析该注解的工作流程. EnableAutoConfiguration注解 启用Sprin ...
- [转帖]OceanBase实验4:迁移MySQL数据到OceanBase集群
服务器环境 1)12核48G,操作系统为centos 7.9系统,单节点三副本1-1-1集群. 2)源MySQL数据库:与OceanBase同一台服务器,版本为MySQL 5.7. 1.使用 mysq ...
- [转帖]使用 TiUP 扩容缩容 TiDB 集群
https://docs.pingcap.com/zh/tidb/stable/scale-tidb-using-tiup TiDB 集群可以在不中断线上服务的情况下进行扩容和缩容. 本文介绍如何使用 ...
- [转帖]linux学习:sed与awk与tr用法整理
https://www.cnblogs.com/LO-gin/p/6882490.html 流编辑器:sed 语法:sed [-hnV][-e<script>][-f<script文 ...
- [转帖]银河麒麟高级服务器操作系统V10SP1安装Docker管理工具(Portainer+DockerUI)
文章目录 一.系统环境配置 二.安装Docker 三.安装Docker管理工具 Docker管理工具之Portainer Portainer简介 Portainer安装 Portainer访问测试 D ...