先说解决办法:
非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查询。问题解决。