C#是否应该限制链式重载的设计模式?
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#是否应该限制链式重载的设计模式?的更多相关文章
- << 链式重载
#include <iostream> using namespace std; class Complex { private: int a, b; public: Complex(in ...
- C++ 运算符重载三(链式编程)
//运算符重载之链式编程 #include<iostream> using namespace std; //对于友元函数重载运算符只适用于左操作数是系统变量的场景 //因为成员无法在系统 ...
- 用php实现一个简单的链式操作
最近在读<php核心技术与最佳实践>这本书,书中第一章提到用__call()方法可以实现一个简单的字符串链式操作,比如,下面这个过滤字符串然后再求长度的操作,一般要这么写: strlen( ...
- hdu2647 逆拓扑,链式前向星。
pid=2647">原文地址 题目分析 题意 老板发工资,可是要保证发的工资数满足每一个人的期望,比方A期望工资大于B,仅仅需比B多1元钱就可以.老板发的最低工资为888元.输出老板最 ...
- 模拟jquery链式访问
一直写代码写代码,博客都快荒废了,眼看一月要过完,不能不留下点记忆,嘿嘿,刚研究了下jquery的链式访问,这么好用的技能我赶紧get了下,研究后略微修改,模拟一个简单的链式访问,下面这段代码支持修改 ...
- HDU 2544最短路 【dijkstra 链式前向星+优先队列优化】
最开始学最短路的时候只会用map二维数组存图,那个时候还不知道这就是矩阵存图,也不懂得效率怎么样 经过几个月的历练再回头看最短路的题, 发现图可以用链式前向星来存, 链式前向星的效率是比较高的.对于查 ...
- C++中的链式操作
代码编译环境:Windows7 32bits+VS2012. 1.什么是链式操作 链式操作是利用运算符进行的连续运算(操作).它的特点是在一条语句中出现两个或者两个以上相同的操作符,如连续的赋值操作. ...
- C++线性表的链式存储结构
C++实现线性表的链式存储结构: 为了解决顺序存储不足:用线性表另外一种结构-链式存储.在顺序存储结构(数组描述)中,元素的地址是由数学公式决定的,而在链式储存结构中,元素的地址是随机分布的,每个元素 ...
- C#用链式方法表达循环嵌套
情节故事得有情节,不喜欢情节的朋友可看第1版代码,然后直接跳至“三.想要链式写法” 一.起缘 故事缘于一位朋友的一道题: 朋友四人玩LOL游戏.第一局,分别选择位置:中单,上单,ADC,辅助:第二局新 ...
- 由表单验证说起,关于在C#中尝试链式编程的实践
在web开发中必不可少的会遇到表单验证的问题,为避免数据在写入到数据库时出现异常,一般比较安全的做法是前端会先做一次验证,通过后把数据提交到后端再验证一次,因为仅仅靠前端验证是不安全的,有太多的htt ...
随机推荐
- 1406, "Data too long for column 'od_seq' at row 1"
问题描述:1406, "Data too long for column 'od_seq' at row 1" 问题分析:录入数据长度超出字段的最大限制 解决方法:增加max_le ...
- ET介绍——组件式设计(优化版的ECS)
组件式设计 在代码复用和组织数据方面,面向对象可能是大家第一反应.面向对象三大特性继承,封装,多态,在一定程度上能解决不少代码复用,数据复用的问题.不过面向对象不是万能的,它也有极大的缺陷: 1. 数 ...
- 在开发过程中使用git rebase还是git merge,优缺点分别是什么?
前言 在开发过程中,git rebase 和 git merge 都是常见的代码版本管理工具.它们都能够将分支合并到主分支,并且都有各自的优缺点. git merge git merge 是一种将两个 ...
- Java网络编程----通过实现简易聊天工具来聊聊NIO
前文我们说过了BIO,今天我们聊聊NIO.NIO 是什么?NIO官方解释它为New lO,由于其特性我们也称之为,Non-Blocking IO.这是jdk1.4之后新增的一套IO标准.为什么要用NI ...
- Spring源码:Bean生命周期(终章)
前言 本系列前面讲解了Spring的bean定义.bean实例化.bean初始化等生命周期.这些步骤使我们能够了解bean从创建到准备好使用所经历的过程.但是,除了这些步骤,bean的销毁也是非常重要 ...
- web自动化03-xpath定位
目标: Xpath方法 1.定位一组元素的方法 element = driver.find_elements_by_*("*") * 可以是name,tag_ ...
- Lombok注解及其作用
Lombok是一个Java库,通过使用注解简化Java类的开发,减少冗余的样板代码.以下是一些常用的Lombok注解及其作用: 1. `@Data`:生成所有属性的getter.setter.`toS ...
- 【电脑Tips】Win11自动更新之后开机黑屏
目录 0.问题描述 1. 释放静电 具体操作 效果 参考博客 2. 运行explorer.exe 具体操作: [问题]:如何打开任务管理器? 效果 参考博客 另外的运行方法 3. 禁用APP Read ...
- 全志G2D实现屏幕旋转,开机logo实现手动旋转。
产品设计出来之后啊,大家使用的时候觉得反过来使用更加便捷.但是屏幕显示是反的.那怎么办那????? 修改硬件费时费工,那能否软件实现那????? 如果纯软件使用那就太费系统资源了.于是就想到了使用全志 ...
- Hugging News #0703: 在浏览器中运行 Whisper 模型、WAIC 分论坛活动邀请报名
每一周,我们的同事都会向社区的成员们发布一些关于 Hugging Face 相关的更新,包括我们的产品和平台更新.社区活动.学习资源和内容更新.开源库和模型更新等,我们将其称之为「Hugging Ne ...