1、导航属性 ManyToOne

ManyToOne 导航属性通过 ToList(includeNestedMembers: false) 加载,参数说明:

false: 返回 2级 Join 的数据(默认);

true: 返回所有层级深度 Join 的导航数据;

Select<Tag>().Include(a => a.Parent).ToList();

Select<Tag>().Where(a => a.Parent.Name == "1").ToList();
//这样写,不需要再标记 Join,解析表达式时自动处理成 LeftJoin

2、导航属性 OneToMany/ManyToMany

IncludeMany 贪婪加载集合的导航属性,其实是分两次查询,在 ToList 后进行了数据重装。

Select<Tag>().IncludeMany(a => a.Songs).ToList();

IncludeMany 有第二个参数,可以进行二次查询前的修饰工作。

Select<Tag>().IncludeMany(a => a.Songs,
then => then.Where(song => song.User == "admin")).ToList();

其实在 then 那里,还可以继续进行向下 Include/IncludeMany。只要你喜欢,向下 100 层都没问题。

3、变异

没有配置导航关系,也可以贪婪加载。

Select<Tag>().IncludeMany(a => a.TestManys.Where(b => b.TagId == a.Id));

只查询每项子集合的前几条数据,避免像EfCore加载所有数据导致IO性能低下(比如某商品下有2000条评论)。

Select<Tag>().IncludeMany(a => a.TestManys.Take(10));

子集合返回部分字段,避免字段过多的问题。

Select<Tag>().IncludeMany(a => a.TestManys.Select(b => new TestMany { Title = b.Title ... }));

4、IncludeMany 扩展方法

当主数据已存在内存中,子数据怎么加载?所以我们增加了 List<T> 扩展方法,示例如下:

new List<Song>(new[] { song1, song2, song3 }).IncludeMany(fsql, a => a.Tags);

5、IncludeMany 两种方式对比

方式一(IncludeMany 扩展方法):

var list111 = fsql.Select<SysModule>()
.Page(1, 10)
.ToList(a => new { Id = a.Id }) //查询数据 id
.Select(a => new SysModule { Id = a.Id }).ToList() //内存操作
.IncludeMany(fsql, a => a.Permissions, then => then.Include(a => a.Button));
SELECT a."Id" as1
FROM "SysModule" a
limit 0,10 SELECT a."Id", a."SysModuleId", a."SysModuleButtonId", a."Status",
a__Button."Id" as5, a__Button."Name", a__Button."EventName", a__Button."EnCode", a__Button."Icon", a__Button."Sort", a__Button."CreateTime"
FROM "SysModulePermission" a
LEFT JOIN "SysModuleButton" a__Button ON a__Button."Id" = a."SysModuleButtonId"
WHERE ((a."SysModuleId") in ('menu1','menu2'))

方式二(直接 IncludeMany + ToList):

var list222 = fsql.Select<SysModule>()
.IncludeMany(m => m.Permissions, then => then.Include(a => a.Button))
.Page(1, 10)
.ToList();
SELECT a."Id", a."ParentId", a."Name", a."Icon", a."UrlAddress", a."IsShow", a."Sort", a."Description", a."CreateTime"
FROM "SysModule" a
limit 0,10 SELECT a."Id", a."SysModuleId", a."SysModuleButtonId", a."Status",
a__Button."Id" as5, a__Button."Name", a__Button."EventName", a__Button."EnCode", a__Button."Icon", a__Button."Sort", a__Button."CreateTime"
FROM "SysModulePermission" a
LEFT JOIN "SysModuleButton" a__Button ON a__Button."Id" = a."SysModuleButtonId"
WHERE ((a."SysModuleId") in ('menu1','menu2'))

案例:查询 Vod 表,分类1、分类2、分类3 各10条数据

class Vod {
public Guid Id { get; set; }
public int TypeId { get; set; }
} //定义临时类,也可以是 Dto 类
class Dto {
public int TypeId { get; set; }
public List<Vod> Vods { get; set; }
} var dto = new [] { 1,2,3 }.Select(a => new Dto { TypeId = a }).ToList();
dto.IncludeMany(d => d.Vods.Take(10).Where(vod => vod.TypeId == d.TypeId)); //执行后,dto 每个元素.Vods 将只有 10条记录

参考资料

系列文章导航

最新文章

  1. 【BZOJ-1976】能量魔方Cube 最小割 + 黑白染色
  2. CSS 中如何把 Span 标签设置为固定宽度
  3. ubuntu12.04 修改 主机名(hostname)
  4. HTML data属性简介以及低版本浏览器兼容算法
  5. bzoj3036: 绿豆蛙的归宿
  6. mysql全库备份数据库脚本
  7. 访问者模式(Visitor)
  8. 关于URL重写
  9. Invalid command &#39;RailsBaseURI&#39;
  10. React-Native(三):React Native是基于React设计的
  11. __x__(31)0908第五天__导航条的练习 &lt;ul&gt; 版本
  12. [Mac] How do I move a window whose title bar is off-screen?
  13. PMO在组织中实现价值应做的工作
  14. .net core consul grpc--系统服务RPC实现通信(一)
  15. for 与 for in
  16. 全国高校绿色计算大赛 预赛第一阶段(C++)第3关:旋转数组
  17. C++中的set
  18. VMware虚拟机下Linux系统的全屏显示
  19. 用Html5与Asp.net MVC上传多个文件
  20. Linux安装配置SVN服务器

热门文章

  1. nodeJs跨域设置(express,koa2,eggJs)
  2. 算法与数据结构基础 - 排序(Sort)
  3. volatile关键字的详解-并发编程的体现
  4. ubuntu-18.10 虚拟机 配置网络环境
  5. Python RPC 之 gRPC
  6. PostgreSQL入门教程(命令行)
  7. flask入门 七行代码讲解
  8. 利用ShardingSphere-JDBC实现分库分表
  9. 设计模式(C#)——12责任链模式
  10. [Python] Django框架入门