1、代码的可阅读性

一眼看懂是什么意思,并且能看出生成的SQL是什么样的

   var list = db.Queryable<Student>()
.GroupBy(it => it.Name)
.Where(it=>it.Id>0)
.Select(it => new {
idAvg = SqlFunc.AggregateAvg(it.Id),
count = SqlFunc.AggregateCount(it.Id),
name = it.Name })
.ToList(); //此代码来自SqlSugar ORM

下面这么写可能就看不懂是什么意思,根看看不出哪个是条件哪个是分组

db.Query(it=>it.Name,
it.Id>0,
it => new {
idAvg = SqlFunc.AggregateAvg(it.Id),
count = SqlFunc.AggregateCount(it.Id),
name = it.Name })//看不懂什么意思

2、易编写和可扩展

如果不用链式重载下面参数越写越多,你让用的人怎么去调,光看这些重载眼睛都要看花,并且封装方法的人也不舒服,写的代码的人工作量也大大家都不舒服。

db.Query(group,where,select,orderby,page)
db.Query(group,where,select,orderby)
db.Query(group,where,select)
db.Query(group,where)
db.Query(group)

上面的还能接受下面的就破防了,因为链式重载函数的可以重复使用

//用链式重载可以有多次使用同一个参数
.OrderBy(it=>it.Id)
.OrderBy(it=>it.Name)
.OrderBy(it=>it.Price)
//那你下面的代码怎么改没办法改了吧哈哈 
db.Query(group1,group2,group3,where1,where2,where3,orderby1,Orderby2,Orderby3........)

3、什么时候适合链式重载

一般95%参数的顺序没有要求的时候可以用链式重,意就是说

Where、OrderBy、Group这些函数的顺序没有要求的时候

总结:

使用链式是一有远见的设计方案,你要考虑到未来需求无限增长的情况

就拿EF Core来说只是查询用了链式重载,插入、更新和删除没有使用链式重载

这就导致他插入更新和删除功能受到了严重的限制, 下面的功能SqlSugar五年前就有了

EF Core8近期才免强支持,整整晚了五年

var result= db.Updateable<Student>()
.SetColumns(it => it.Num== it.Num+1)
.Where(it => it.Id == 1)
.ExecuteCommand();

SqlSugar正因设计的长远,使用了链式功能想怎么加就怎么加,SqlSuar在EF Core停滞的五年又加了很多功能 秀一下

//分页更新除低内存,可以自动调节最佳性能
db.Updateable(List<实体>).PageSize(1000).ExecuteCommand() //条件更新
db.Updateable<Order>()
.SetColumnsIF(p!=null ,it => it.CreateTime == p.Value)
.SetColumnsIF(X!=null ,it => it.X== X)
.Where(it => it.Id == 11).ExecuteCommand(); //联表更新
var t= db.Updateable<Order>()
.InnerJoin<Custom>((x, y) => x.CustomId == y.Id)
.SetColumns((x, y) => new Order() { Name = y.Name, Price = y.Id })
.Where((x, y) => x.Id == 1)
.ExecuteCommand(); //批量 字段+list[i].字段
db.Updateable(list)
PublicSetColumns(it => it.Price, "+") //set price=price+list[i].price
.ExecuteCommand(); //字典集合更新
var dtList = new List<Dictionary<string, object>>();
dtList.Add(dt);
dtList.Add(dt2);
var t666 = db.Updateable(dtList).AS("student").WhereColumns("id").ExecuteCommand(); //无实体更新
db.Updateable<object>()
.AS("Order")
.SetColumns("name", 1)
.Where("id=1").ExecuteCommand(); //导航更新,可以方便的指定更新层级
db.UpdateNav(list)
.Include(z1 => z1.Books)
.ThenInclude(z1 => z1.RoomList)
.ExecuteCommand(); //分表更新
db.Insertable(data).SplitTable().ExecuteCommand();
//分表在分页更新
db.Insertable(data).SplitTable().PageSize(1000).ExecuteCommand();

  

C#是否应该限制链式重载的设计模式?的更多相关文章

  1. << 链式重载

    #include <iostream> using namespace std; class Complex { private: int a, b; public: Complex(in ...

  2. C++ 运算符重载三(链式编程)

    //运算符重载之链式编程 #include<iostream> using namespace std; //对于友元函数重载运算符只适用于左操作数是系统变量的场景 //因为成员无法在系统 ...

  3. 用php实现一个简单的链式操作

    最近在读<php核心技术与最佳实践>这本书,书中第一章提到用__call()方法可以实现一个简单的字符串链式操作,比如,下面这个过滤字符串然后再求长度的操作,一般要这么写: strlen( ...

  4. hdu2647 逆拓扑,链式前向星。

    pid=2647">原文地址 题目分析 题意 老板发工资,可是要保证发的工资数满足每一个人的期望,比方A期望工资大于B,仅仅需比B多1元钱就可以.老板发的最低工资为888元.输出老板最 ...

  5. 模拟jquery链式访问

    一直写代码写代码,博客都快荒废了,眼看一月要过完,不能不留下点记忆,嘿嘿,刚研究了下jquery的链式访问,这么好用的技能我赶紧get了下,研究后略微修改,模拟一个简单的链式访问,下面这段代码支持修改 ...

  6. HDU 2544最短路 【dijkstra 链式前向星+优先队列优化】

    最开始学最短路的时候只会用map二维数组存图,那个时候还不知道这就是矩阵存图,也不懂得效率怎么样 经过几个月的历练再回头看最短路的题, 发现图可以用链式前向星来存, 链式前向星的效率是比较高的.对于查 ...

  7. C++中的链式操作

    代码编译环境:Windows7 32bits+VS2012. 1.什么是链式操作 链式操作是利用运算符进行的连续运算(操作).它的特点是在一条语句中出现两个或者两个以上相同的操作符,如连续的赋值操作. ...

  8. C++线性表的链式存储结构

    C++实现线性表的链式存储结构: 为了解决顺序存储不足:用线性表另外一种结构-链式存储.在顺序存储结构(数组描述)中,元素的地址是由数学公式决定的,而在链式储存结构中,元素的地址是随机分布的,每个元素 ...

  9. C#用链式方法表达循环嵌套

    情节故事得有情节,不喜欢情节的朋友可看第1版代码,然后直接跳至“三.想要链式写法” 一.起缘 故事缘于一位朋友的一道题: 朋友四人玩LOL游戏.第一局,分别选择位置:中单,上单,ADC,辅助:第二局新 ...

  10. 由表单验证说起,关于在C#中尝试链式编程的实践

    在web开发中必不可少的会遇到表单验证的问题,为避免数据在写入到数据库时出现异常,一般比较安全的做法是前端会先做一次验证,通过后把数据提交到后端再验证一次,因为仅仅靠前端验证是不安全的,有太多的htt ...

随机推荐

  1. 2021-12-19:找到所有数组中消失的数字。 给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums

    2021-12-19:找到所有数组中消失的数字. 给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内.请你找出所有在 [1, n] 范围内但没有出现在 nums ...

  2. 6R机械臂运动规划及仿真

    博客地址:https://www.cnblogs.com/zylyehuo/ 参考链接 Moveit!机械臂控制 文件下载-古月ROS教程视频配套资料 解决Could not find a packa ...

  3. [学习笔记]解决因C#8.0的语言特性导致EFCore实体类型映射的错误

    今天下午在排查一个EF问题时,遇到了个很隐蔽的坑,特此记录. 问题 使用ef执行Insert对象到某表时报错,此对象的Address为空: 不能将值 NULL 插入列 'Address',表 'dbo ...

  4. 2014年蓝桥杯C/C++大学B组省赛真题(地宫寻宝)

    题目描述: X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. ...

  5. python 学习之-----正则表达式

    mport re'''# re 模块regex 正则表达式,正则表达式应用范围:1爬虫:2自动化运维--开发自动化:# 什么是正则表达式:一套规则: 匹配字符串的规则# 能做什么 1 检测一个输入的字 ...

  6. STM32F429 Discovery开发板应用:实现SPI-SD Card文件写入(搭载FatFS文件系统)

    MCU:STM32F429ZIT6 开发环境:STM32CubeMX+MDK5 外购了一个SPI接口的SD Card模块,想要实现SD卡存储数据的功能. 首先需要打开STM32CubeMX工具.输入开 ...

  7. 【IntelliJ】添加javaweb、tomcat语法支持

    默认情况下:idea不支持javaweb的语法 但,我们的期望是: 解决方法:配置tomcat如下: (假设你已经配置好了tomcat)接下来: 1.打开[项目结构(快捷键:Ctrl + Shift ...

  8. Curl 中 关于PUT, POST, DELETE, UPDATE 的使用

    POST curl -H "Content-Type:application/json" -X POST --data '{"id":1, "text ...

  9. springboot使用Websocket写一个聊天室

    1 <!--websocket 依赖--> 2 <dependency> 3 <groupId>org.springframework.boot</group ...

  10. 记一次.Net分布式事务死锁现象以及解决方法

    在本文中,将介绍一次遇到的.Net分布式事务死锁现象以及解决方法.我们将首先了解事务框架的构成,然后分析导致死锁的代码,最后提出解决方法. 事务框架 本次开发框架JMSFramework将分布式事务划 ...