类别:学习文档
日期:2021-07-15 浏览:2175 评论:0
原本不支持 IQueryable 主要出于使用习惯的考虑,编写代码的智能总会提示出现一堆你不想使用的方法(对不起,我有强迫症),IQueryable 自身提供了一堆没法实现的方法,还有外部入侵的扩展方法,严重影响编码体验。如下图:
v1.4.0+ 版本请使用以下命令安装(老版本不需要安装):
dotnet add package FreeSql.Extensions.Linq
特别说明
请尽量不要在 ISelect 模式下的使用 Linq 方法:GroupJoin、Select、SelectMany、Join、DefaultIfEmpty;
如果一定要在 ISelect 中使用 .Select() 方法,请务必在 .ToList() 之前调用它;
IQueryable
FreeSql 提供强大的数据查询对象 ISelect。
FreeSql.Extensions.Linq v1.4.0+ 实现了 IQueryable 查询对象常用功能,以便在各框架中交互使用。
//将 ISelect 转为 IQueryable IQueryable<Student> queryable = fsql.Select<Student>().AsQueryable(); //Linq 方法查询 var t1 = queryable.Where(a => a.id == 1).FirstOrDefault(); //将 IQueryable 还原为 ISelect ISelect<Studeng> select = queryable.RestoreToSelect();
注意:IQueryable 的实现目前不支持 GroupBy,可以考虑使用 RestoreSelect 方法转回 ISelect 进行查询
Where
var t1 = ( from a in fsql.Select<Student>() where a.id == item.id select a ).ToList();
Select(指定字段)
var t1 = ( from a in fsql.Select<Student>() where a.id == item.id select new { a.id } ).ToList();
CaseWhen
var t1 = ( from a in fsql.Select<Student>() where a.id == item.id select new { a.id, a.name, testsub = new { time = a.age > 10 ? "大于" : "小于或等于" } } ).ToList();
Join
var t1 = ( from a in fsql.Select<Student>() join b in fsql.Select<School>() on a.id equals b.StudentId select a ).ToList(); var t2 = ( from a in fsql.Select<Student>() join b in fsql.Select<School>() on a.id equals b.StudentId select new { a.id, bid = b.id } ).ToList(); var t3 = ( from a in fsql.Select<Student>() join b in fsql.Select<School>() on a.id equals b.StudentId where a.id == item.id select new { a.id, bid = b.id } ).ToList();
LeftJoin
var t1 = ( from a in fsql.Select<Student>() join b in fsql.Select<School>() on a.id equals b.StudentId into temp from tc in temp.DefaultIfEmpty() select a ).ToList(); var t2 = ( from a in fsql.Select<Student>() join b in fsql.Select<School>() on a.id equals b.StudentId into temp from tc in temp.DefaultIfEmpty() select new { a.id, bid = tc.id } ).ToList(); var t3 = ( from a in fsql.Select<Student>() join b in fsql.Select<School>() on a.id equals b.StudentId into temp from tc in temp.DefaultIfEmpty() where a.id == item.id select new { a.id, bid = tc.id } ).ToList();
From(多表查询)
var t1 = ( from a in fsql.Select<Student>() from b in fsql.Select<School>() where a.id == b.StudentId select a ).ToList(); var t2 = ( from a in fsql.Select<Student>() from b in fsql.Select<School>() where a.id == b.StudentId select new { a.id, bid = b.id } ).ToList(); var t3 = ( from a in fsql.Select<Student>() from b in fsql.Select<School>() where a.id == b.StudentId where a.id == item.id select new { a.id, bid = b.id } ).ToList();
GroupBy(分组)
var t1 = ( from a in fsql.Select<Student>() where a.id == item.id group a by new {a.id, a.name } into g select new { g.Key.id, g.Key.name, cou = g.Count(), avg = g.Avg(g.Value.age), sum = g.Sum(g.Value.age), max = g.Max(g.Value.age), min = g.Min(g.Value.age) } ).ToList();
系列文章导航
FreeSql (一)入门及安装 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二)自动迁移实体 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三)实体特性 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (四)实体特性 Fluent Api - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (五)插入数据 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (六)批量插入数据 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (七)插入数据时忽略列 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (八)插入数据时指定列 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (九)删除数据 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十)更新数据 - 学习文档 - 零一的世界 (vtzw.com)FreeSql (十一)更新数据 Where - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十二)更新数据时指定列 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十三)更新数据时忽略列 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十四)批量更新数据 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十五)查询数据 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十六)分页查询 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十七)联表查询 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十八)导航属性 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (十九)多表查询 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十)多表查询 WhereCascade - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十一)查询返回数据 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十二)Dto 映射查询 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十三)分组、聚合 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十四)Linq To Sql 语法使用介绍 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十五)延时加载 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十六)贪婪加载 Include、IncludeMany - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十七)将已写好的 SQL 语句,与实体类映射进行二次查询 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十八)事务 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (二十九)Lambda 表达式 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三十)读写分离 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三十一)分表分库 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三十二)Aop - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三十三)CodeFirst 类型映射 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三十四)CodeFirst 迁移说明 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三十五)CodeFirst 自定义特性 - 学习文档 - 零一的世界 (vtzw.com)
FreeSql (三十六)进阶 仓储系列文档 - 学习文档 - 零一的世界 (vtzw.com)
发表评论 / 取消回复