1.问题的现象

 public class LinqHepler<T> where T:class
{
private EFDBContext _context = null;
/// <summary>
///
/// </summary>
/// <param name="context"></param>
public LinqHepler(EFDBContext context)
{
_context = context; }
/// <summary>
///
/// </summary>
/// <param name="whereLambda"></param>
/// <returns></returns>
public IQueryable<T> LoadEntities(Func<T, bool> whereLambda)
{
return _context.Set<T>().Where(whereLambda).AsQueryable();
}
/// <summary>
///
/// </summary>
/// <param name="whereLambda"></param>
/// <returns></returns>
public IQueryable<T> LoadEntitiesExpression(Expression<Func<T, bool>> whereLambda)
{
return _context.Set<T>().Where(whereLambda).AsQueryable();
}
}
[HttpGet]
[Route("LinqWhere")]
public IActionResult LinqWhere()
{
string uname = "";
_context.UserInfo.Where(c => c.UserName == uname).ToList();//带条件
LinqHepler<UserInfo> linqHepler = new LinqHepler<UserInfo>(_context);
linqHepler.LoadEntities(c => c.UserName == uname).ToList();//查全表
linqHepler.LoadEntitiesExpression(c => c.UserName == uname).ToList();//不查全表
return Ok();
}

生产的sql

2017-10-11T02:59:22.495010Z 2328 Query SELECT `c`.`UserId`, `c`.`UserName`, `c`.`UserPwd`
FROM `UserInfo` AS `c`
WHERE `c`.`UserName` = ''
2017-10-11T02:59:22.538041Z 2328 Query SELECT `u`.`UserId`, `u`.`UserName`, `u`.`UserPwd`
FROM `UserInfo` AS `u`
2017-10-11T02:59:22.551050Z 2328 Query SELECT `c`.`UserId`, `c`.`UserName`, `c`.`UserPwd`
FROM `UserInfo` AS `c`
WHERE `c`.`UserName` = ''

可见,第一个是用EF对象直接调用Linq的扩展方法Where可以生成对应的Where条件,

第二个用泛型传递要查学的实体类型和Where条件去查询,这时没有生产对应的Where条件的sql

第三个加了Expession类型包装Func对象有生产Where sql

参考大神的解释

园友问:EF写linq的时候,生成的SQL不带where条件,给全表都查出来的,请问这是什么原因

0
悬赏园豆:50 [已解决问题] 浏览: 575次
我用的数据仓储,我的查询linq如下:
//查询
public IQueryable<T> Query(Func<T, bool> wherelambda)
{
return db.Set<T>().AsNoTracking<T>().Where<T>(wherelambda).AsQueryable();
}
我的linq是调用该查询方法,但是通过ef sql拦截生成的SQL是全表扫描,而通过监测 sql profile生成的sql也是不带SQL

答:宏观的解释是Expression内部是专门有个解析器privoder,会根据条件解析成相应sql并执行到数据库,而Func这个破委托类型没有这种专业的sql解析器,没法生成你想要的sql,直接是等默认全表加载后在内存中筛选。

总结

框架是照超来的,结果发现有很大的问题,可能是之前检索问题的方式不对,或者是这个问题太简单了,竟然很久才找到答案,原来是linq的基础知识;

果然还是不能照抄照搬,我后来查看linq的所有方法参数中都带有这个关键字,希望对大家有帮助;

Linq To EF 用泛型时生成的Sql会查询全表的问题的更多相关文章

  1. 数据库表设计时一对一关系存在的必要性 数据库一对一、一对多、多对多设计 面试逻辑题3.31 sql server 查询某个表被哪些存储过程调用 DataTable根据字段去重 .Net Core Cors中间件解析 分析MySQL中哪些情况下数据库索引会失效

    数据库表设计时一对一关系存在的必要性 2017年07月24日 10:01:07 阅读数:694 在表设计过程中,我无意中觉得一对一关系觉得好没道理,直接放到一张表中不就可以了吗?真是说,网上信息什么都 ...

  2. mysql-update时where条件无索引锁全表

          1 5.3日数据处理需求 UPDATE md_meter set warranty_end_date = DATE_ADD(warranty_begin_date,INTERVAL 10 ...

  3. Linq以本周和本月为条件的Sql,Liqn查询本周,Linq查询本月

    //计算本周时间 时间 > DateTime.Now.AddDays(-Convert.ToInt32(DateTime.Now.Date.DayOfWeek) //计算本月时间 时间 > ...

  4. EF ( Entity Framework) 操作ArcCataLog 生成的(Sql Server)空间数据库

    因为项目需求,现在需要利用EF 操作由Arccatalog生成的sql server空间数据库..在此之前,一直没有接触过空间数据库,在操作空间数据库时 绕了许多弯... 因此写一篇随笔做一个总结. ...

  5. 避免SQL全表模糊查询查询 下载文件时-修改文件名字

    避免SQL全表模糊查询查询   1.模糊查询效率很低: 原因:like本身效率就比较低,应该尽量避免查询条件使用like:对于like %...%(全模糊)这样的条件,是无法使用索引的,全表扫描自然效 ...

  6. linq和EF查询的用法和区分

    我们做项目时,难免会遇到用的不知道是啥,及把linq和EF搞混了 今天我带领大家梳理下思路: 首先说linq查询,然后介绍EF查询 1.linq查询 当我们使用linq查询时,转到定义会调到Query ...

  7. C#连接Sqlite 出现:混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集。的解决方案

    C#连接Sqlite 出现: 混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集.的解决方案 C#连接sqlite数据库代码 ...

  8. Java进击C#——应用开发之Linq和EF

    本章简言 上一章笔者对于WinForm开发过程用到的几个知识点做了讲解.笔者们可以以此为开端进行学习.而本章我们来讲一个跟ORM思想有关的知识点.在讲之前让我们想一下关于JAVA的hibernate知 ...

  9. EF查询生成的SQL

    在EF 4和EF 3.5 SP1中,我们可以使用ToTraceString()方法得到EF查询所生成的SQL. using (var context = new TestDBEntities()) { ...

随机推荐

  1. three.js 着色器材质内置变量

    这篇郭先生说一下three.js着色器的内置变量,分别是 gl_PointSize:在点渲染模式中,控制方形点区域渲染像素大小(注意这里是像素大小,而不是three.js单位,因此在移动相机是,所看到 ...

  2. 轻轻松松学CSS:position

    position属性表示元素的定位类型,在CSS布局中,position发挥着非常重要的作用,一些元素的布局就是用position完成的,鉴于此,本文结合一些小实例详细讲解一下. position属性 ...

  3. SG 函数学习

    \(Mex\) 运算 \(mex(S)\) 为不属于集合 \(S\) 的最小非负整数,即: \[mex(S)=\min \limits_{x \in \mathbb{N},x \not\in S} \ ...

  4. ybt1107题解和方法总结

    今天花了三个小时的时间刷了些基础题,虽说是简单题,但是有一些还是有点难度的 比如ybt1107,我死嗑了半个小时. [题目描述] 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米. ...

  5. webpack系列之loader的基本使用

    可以访问 这里 查看更多关于大数据平台建设的原创文章. webpack系列之loader及简单的使用 一. loader有什么用 webpack本身只能打包Javascript文件,对于其他资源例如  ...

  6. Html5与CSS3(选择器)

    <!-- 作者:offline 时间:2018-03-21 描述:1.全选择器 *{属性1:属性值2:属性2:属性值2:...:} 2.元素(标签)选择器 标签名{属性1:属性值2:属性2:属性 ...

  7. Spark QuantileDiscretizer 分位数离散器

    1.概念 接收具有连续特征的列,并输出具有合并分类特征的列.按分位数,对给出的数据列进行离散化分箱处理. 和Bucketizer(分箱处理)一样也是:将连续数值特征转换为离散类别特征.实际上Class ...

  8. Jmeter 常用函数(11)- 详解 __TestPlanName

    如果你想查看更多 Jmeter 常用函数可以在这篇文章找找哦 https://www.cnblogs.com/poloyy/p/13291704.html 作用 返回测试计划名称 语法格式 ${__T ...

  9. 树链剖分详解&题解 P6098 【[USACO19FEB]Cow Land G】

    看到各位大佬们已经把其他的东西讲的很明白了,我这个 juruo 就讲一讲最基本的树链剖分吧. 0.树剖是什么?能吃吗? 不能吃 树剖是树链剖分的简称,我们一般说的树剖其实指重链剖分.当然,还有一种长链 ...

  10. 符合SEO的网站标题应该怎么写

    http://www.wocaoseo.com/thread-96-1-1.html 的seo网站标题既能提起读者的点击欲望,又能搜索引擎中获得好的排名,这两着之间有着有有一些联系,网站的标题若要从s ...