ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

FreeSql学习笔记——11.LinqToSql

2022-06-07 11:01:21  阅读:186  来源: 互联网

标签:11 Name FreeSql Linq ISelect LinqToSql freeSql sc Select


前言

  Linq的强大大家有目共睹,可以以简便的方式对数据集进行复杂操作,LinqToSql经常使用在数据库的联表、分组等查询操作中;FreeSql对LinqToSql的支持通过扩展包FreeSql.Extensions.Linq;    

Init

dotnet add package FreeSql.Extensions.Linq  

 

说明

  • 请尽量不要在 ISelect 模式下的使用 Linq 方法:GroupJoin、Select、SelectMany、Join、DefaultIfEmpty;
  • 如果一定要在 ISelect 中使用 .Select() 方法,请务必在 .ToList() 之前调用它;
  • IQueryable 的实现目前不支持 GroupBy,可以考虑使用 RestoreSelect 方法转回 ISelect 进行查询
 

ISelect与Queryable的转换

var query = _freeSql.Select<Student>().AsQueryable();
query.RestoreToSelect();
   

示例

(from s in _freeSql.Select<Student>()
     select s).ToList();
SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM [Student] a


(from s in _freeSql.Select<Student>()
 join c in _freeSql.Select<Class>() on s.ClassId equals c.Id into temp
 from sc in temp.DefaultIfEmpty()
 where s.Status == StatusEnum.Normal
 select new
 {
     SName = s.Name,
     CName = sc.Name
 })
.Page(2, 10)
.ToList();

SELECT a.[Name] as1, sc.[Name] as2
FROM [Student] a
LEFT JOIN [Class] sc ON a.[ClassId] = sc.[Id]
WHERE (a.[Status] = 1)
ORDER BY a.[Id]
OFFSET 10 ROW
FETCH NEXT 10 ROW ONLY
 
Linq查询,联表使用较好,分组查询还是得使用ISelect,运用ISelect、IQueryable转换可以实现复杂查询

标签:11,Name,FreeSql,Linq,ISelect,LinqToSql,freeSql,sc,Select
来源: https://www.cnblogs.com/zousc/p/16350989.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有