ef联表查询速度_EF Join连接查询的坑

最近做项目的时候遇到一个需要级联查询的数据,表中又没有定义相关的外键约束,所以限定了咱们只能使用Join方式的关联而不是Include的方式关联,关于Include和Join的详细用法,本屌就不再此处进行详细说明了。园子里相关的文章有很多,大家请自行去查看!

废话不多说,直接上代码:

说明:1.ef的Join级联查询生成的语句是Inner Join 的方式,所以此处生成的脚本语句应该类似下面的形式:

select * from TableNameA A

Inner Join TableNameB B

where ...相关条件...

2.图一中的标红的1表示关联的表 也就是TableNameB的名字   2表示级联的数据集

3.通过检测数据库可以发现生成的脚本如下:

备注:红色圆圈内的标记  说明我们的猜测是正确的。

大家再来看看这种情况的查询:

说明:图一和图二的不同点就在红色标记2

我们再次监测数据库生成的脚本:

说明:我们发现生成的脚本并不和我们所想象的一样,而是先查询除关联表的数据再取出符合条件的。这样就比较耗时了。

z总结:经过多方资料的查询发现:原来使用Join关联的时候,关联字段值的名字需要一样才会使用Inner的级联方式查询,如果不一样的话,会使用类似第二种的这种查询方式进行查询。

自己遇到的坑,在此处进行记录下,防止下次继续踩坑。  备注:这个还是有其他的解决方案的,详情这个大神的文章《http://www.cnblogs.com/dudu/archive/2011/04/04/entity_framework_map_inner_join.html#commentform》

写在最后:本屌才疏学浅,要是有写的不妥的地方,还望各位大虾们勿喷!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值