ef 多表查询疑问

wilson2017 2017-02-04 10:54:26
使用 ef 的方式进行多表查询:

var list = t.getlist(); // 第一次连接?
var list2 =x.getlist(); //第二次连接?

var newList=t.join(...) // 两个 list 组合查询 ,如果数据量大的时候不是很坑?

使用 sql 多表查询:
select * from table1 t1 join table2 t2 on t1.id=t2.id




这样同时获取两个列表再 join 不等于需要去数据库请求两次,相比用原生的 sql 去请求还多了一次,而且还用再进行两个 list 的组合查询,感觉非常坑。初次接触 ef 这种方式,不知道是不是自己理解有误,求大神指教


...全文
251 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
更具体地说,基于 Linq 机制的系统,即使在执行 var newList=t.join(...) 这条语句的时候,也根本不去查询数据。只有后边遇到 ToList、Count、Any 等等操作的时候,才真正解析 Linq 表达式(或者取出之前缓存结果)然后产生数据库查询 sql。 所以,许多 Linq Provider 产生的最终的查询 sql,就是想你手动写 sql 语句那样,是一条原生的 join 关系数据库查询语句。并不是你想象的“多次查询”。
  • 打赏
  • 举报
回复
你在使用 ef 这类 ORM 的时候,至少要先得到其发送给数据库系统的原生 sql 语句,再来分析!Linq 机制是“延迟加载”的,在实际查询之前,Linq Provider 会做动态分析工作并且产生最终的 sql 语句。所以是不是真的“两次连接”要实际测试,通常只有在 linq 表达式不能正确解析的情况下才会“多次连接”。并不是你认为的那样。
  • 打赏
  • 举报
回复
自己写出测试程序(打乱次序测试1000次然后给出统计平均值),贴出结果,以测试数据来判断。

62,075

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧