关于在Entity Framework中非Linq语句左连接的实现

 先说解决办法:

非Linq方式的左连接方式很多,这里是基于原来搭建好的框架写的。

若想实现左连接,在撰写以下代码时应在尾部加上  .DefaultIfEmpty();

var tempData = dbcontext.Set<TEntity>().Where(predicate);

 正文

因为是在已有的框架上去更新、开发功能,所以很多情况下无法动基础的代码,最多也只能扩展,找了许久也没个头绪,都说的是Linq的左连接,要么就是有此类问题的帖子,可又没什么用。

以下时初始定义的代码:

var tempData = dbcontext.Set<TEntity>().Where(predicate);

dbcontext为EF框架中的上下文,其他的就不说了,都能看懂,不明白还是先摸摸EF框架吧。

问题描述:经EF框架从数据库中对多张表关联查询相关数据,查询时返回总条数20条,但是只显示了3条。

分析:

首先想到自己做了分页功能,可能是分页的时候参数传递错误,后来发现不是,pass。

其次,在后续的过程中还调用EF框架中的方法Include,这是System.MVC.Data中IQueryable的内容,但也不是这个问题,切入点错误,pass。

foreach (string i in paths)
{
    tempData = tempData.Include(i);
}

 最后还是的切到初始的查询定义上来,即 tempData 该如何定义

原因分析:

在经过调试,跟踪数据库后发现,tempData 查询语句执行的时INNER JOIN,这是导致显示与总条数不一致的原因,INNER JOIN会过滤掉没有匹配项的数据。

怎么办:

使用LEFT JOIN,及左连接 

如下修改代码,在尾部加上DefaultIfEmpty():

var tempData = dbcontext.Set<TEntity>().Where(predicate).DefaultIfEmpty();

执行后跟踪数据库发现此次执行的时LEFT OUT JOIN查询。问题解决。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值