【排序用法】.NET开源 ORM 框架 SqlSugar 系列

.NET开源 ORM 框架 SqlSugar 系列

  1. 【开篇】.NET开源 ORM 框架 SqlSugar 系列
  2. 【入门必看】.NET开源 ORM 框架 SqlSugar 系列
  3. 【实体配置】.NET开源 ORM 框架 SqlSugar 系列
  4. 【Db First】.NET开源 ORM 框架 SqlSugar 系列
  5. 【Code First】.NET开源 ORM 框架 SqlSugar 系列
  6. 【数据事务】.NET开源 ORM 框架 SqlSugar 系列
  7. 【连接池】.NET开源 ORM 框架 SqlSugar 系列
  8. 【查询目录】.NET开源 ORM 框架 SqlSugar 系列
  9. 【查询基础】.NET开源 ORM 框架 SqlSugar 系列

💦万丈高楼平地起,做开发想要技术精进,必须要有扎实的基础功底。基础SQL查询语法一定要牢记于心,才能应对后面更为复杂的形势。

1、OrderBy位置

1.1 Select 前面

cs 复制代码
var list =db.Queryable<Student>()
.LeftJoin<School>((st, sc) =>st.SchoolId==sc.Id)
.OrderBy((st,sc)=>st.SchoolId)//写Select前面用法,正常都这么用
.Select((st,sc)=>new Dto(){ id=it.id ,Name=it.Name})
.ToList();

1.2 Select 后面

💥区别:特殊用法需要写在Select后面,比如Select中有计算列

cs 复制代码
var list =db.Queryable<Student>()
.LeftJoin<School>((st, sc) =>st.SchoolId==sc.Id)
.Select((st,sc)=>new Dto(){ NewNum=st.Num+st.num2,Name=it.Name})
.MergeTable()//需要加上MergeTable对Select后的对象进行排序
.OrderBy(it=>it.NewNum)
.ToList();

2、多列排序

方式1: 逗号隔开 id asc ,name desc

方式2: 链式写法Orderby().Orderby()

cs 复制代码
OrderBy(it=>new {  it.Id, name=SqlFunc.Desc(it.Name) }).ToList();
//id asc ,name desc
 
//也可以多个OrderBy
OrderBy(it=> it.Id).OrderBy(it=> SqlFunc.Desc(it.Name))

3、联表排序

cs 复制代码
var list = db.Queryable<Student>().LeftJoin<School>((st, sc) =>st.SchoolId==sc.Id)
.OrderBy(st=>st.Id)//升序
.OrderBy((st,sc)=>sc.Id,OrderByType.Desc)//写Select前面,写后面看标题1
.Select<ViewModelStudent>().ToList();
// order by st.id, sc.id desc  多级排序

💥注意:如果存在select一定要扔在select前面,不然 st sc别名拿不到

4、动态排序

4.1 字符串排序

💥注意:

  • OrderByPropertyName 需要实体查询
  • OrderBy 都可以
cs 复制代码
//1.Sql字符串,可以防止低级成本注入,支持自定义重写SQL注入验证StaticConfig.Check_FieldFunc重写这个委托方法就可以
var list =db.Queryable<Student>()
.LeftJoin<School>((st, sc) =>st.SchoolId==sc.Id)
.OrderBy("st.id asc,sc.Id desc ") //这种就是填SQL你SQL什么样就是什么样 建议看4.2用法
.Select<ViewModelStudent>().ToList();
//技巧可以通过方法转转拿到真实列名:EntityMaintenance.GetDbColumnName<Order>("Id") 100%防注入
 
//2.属性名排序 ,100%防注入,他会根据类中的名字去验证是否存在,不存在就报错
var list= db.Queryable<Student>().OrderByPropertyName("Id")
           .Toist();//有实体才能用这个,没有实体不能用这个
 
//3.使用合并表排序                       
var list =db.Queryable<Student>()
.LeftJoin<School>((st, sc) =>st.SchoolId==sc.Id)
.Select(it=>new {....})
.MergeTable()
.OrderByPropertyName("Id") //100%防注入,这样的好处可以去掉SQL的别名,适合多表排序
.ToList();

4.2 集合方式排序

cs 复制代码
//新功能推荐
List<OrderByModel> orderList = OrderByModel.Create(  
new OrderByModel(){ FieldName="id",OrderByType=OrderByType.Desc},                     
new OrderByModel(){  FieldName="name"} //默认防注入:并且可以用StaticConfig.Check_FieldFunc重写验证机质
);     
var list=db.Queryable<Student>().AS("order").OrderBy(orderList).ToList();    
 
//技巧:获取类中字段名
 FieldName=db.EntityMaintenance.GetDbColumnName<Order>("Id");//100%防注入

4.3 多表去别名

cs 复制代码
var pageJoin = db.Queryable<Student>()
                .LeftJoin<School>((st, sc) =>st.SchoolId==sc.Id)
                .Select((st, sc) => new {
                 id = st.Id,
                 name = sc.Name
              })
.MergeTable()//将查询结果集变成表MergeTable
.Where(it => it.id == 1).OrderBy("name asc").ToList();//对表MergeTable进行排序

生成的Sql相当于

cs 复制代码
select *  
from 
     (select st.id as id,sc.name as name from xx join xx on ... ) MergeTable  
     --多表已经变成了单表
      where id=@id
      order by ("name asc")

所以单条查询是不需要加前缀的,上面的例子把多表转成了单表操作

5、随机排序取10条

cs 复制代码
db.Queryable<Student>().Take(10).OrderBy(st=>SqlFunc.GetRandom()).ToList(); //随机获取数据

6、OrderByIF

cs 复制代码
OrderByIF(IsOrderBy, it=>it.Id) //当条件IsOrderBy成立.OrderBy才生效

7、ThenBy

💥注意:SqlSugar中没有ThenBy 直接写2次OrderBy就行了

8、取最新10条

cs 复制代码
db.Queryable<Student>().Take(10).OrderBy(st=>SqlFunc.Desc(it.CreateTime)).ToList(); //order by createtime desc
 
//也可以用这个重载
.OrderBy(it=>it.CreateTime,OrderByType.Desc)
相关推荐
studying_mmr1 分钟前
Introduction to NoSQL Systems
数据库·笔记·nosql数据库·database
ZWZhangYu3 分钟前
解决MyBatis在 Oracle 中使用 IN 语句不能超过 1000 问题
数据库·oracle·mybatis
Lill_bin4 分钟前
分页查询在数据库中的好处
java·开发语言·数据库·python·oracle·性能优化
恒辉信达9 分钟前
hhdb客户端介绍(23)
数据库·mysql·hhdb·数据库可视化界面客户端
Cchengzu38 分钟前
百度23届秋招研发岗A卷
开发语言·数据库·c++
编程修仙39 分钟前
MySQL子查询
数据库·mysql
@黄色海岸43 分钟前
【数据分析】表结构数据特征、获取、使用
数据库·数据挖掘·数据分析
吴冰_hogan1 小时前
MySQL事务隔离
数据库·mysql
练小杰1 小时前
我在广州学 Mysql 系列之 数据“表”的基本操作
android·数据库·学习·mysql·adb
gsforget3211 小时前
ORACLE RAC ADG备库报错ORA-04021: timeout occurred while waiting to lock object
数据库·oracle·oracle adg