首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL中WHERE后跟着N多个OR条件会怎样。。。

某工具在运行过程中,会产生下面的SQL进行查询,WHERE后跟了N多个条件: mysql> select * from order_line where (ol_w_id = '1' and ol_d_id...这里说的N多个,是指总共有10000个OR条件,这条SQL的长度大概将近800KB。...当WHERE查询条件里有很多OR、AND组成时,优化器判断超过内存消耗限制,则会调整SQL执行计划,变成其他执行方案,甚至可能是全表扫描。...针对本案中的SQL,更好的优化办法是找出这些OR条件的范围规律,并改写成一条更简单的SQL,类似下面这样: mysql> select * from order_line where ol_w_id =...最后再次提醒,WHERE条件后跟着N多个OR/AND条件的写法非常不可取,尤其是在用一些开发框架构造查询SQL时,尤其要注意规避这个问题,否则可能造成严重性能问题。

1.5K20
您找到你想要的搜索结果了吗?
是的
没有找到

TP5 where数组查询(模糊查询--多个查询条件)

有查询条件就查询,多个查询条件,只要有查询,就增加一个查询条件 一、TP5.1版本 TP运算符 SQL运算符 例子 实际查询条件 eq = $map['id'] = array('eq',100); 等效于...in',array('1','5','8')); exp 表达式 上表中的 exp 不是一个运算符,而是一个综合表达式以支持更复杂的条件设置。...exp 的操作条件不会被当成字符串,可以使用任何 SQL 支持的语法,包括使用函数和字段名称。 ?...exp 不仅用于 where 条件,也可以用于数据更新,如: 官方查询语法:https://www.kancloud.cn/manual/thinkphp5/135182 版本 新增功能 5.0.9 比较运算增加闭包子查询支持...5.0.4 支持对同一个字段多次调用查询方法 查询表达式支持大部分的SQL查询语法,也是ThinkPHP查询语言的精髓,查询表达式的使用格式: where('字段名','表达式','查询条件');

6K20

.NET面试题系列 - LINQ to SQL与IQueryable

名言警句 "理解IQueryable的最简单方式就是,把它看作一个查询,在执行的时候,将会生成结果序列。" - Jon Skeet LINQ to Object和LINQ to SQL有何区别?...LINQ to SQL可以将查询表达式转换为SQL语句,然后在数据库中执行。相比LINQ to Object,则是将查询表达式直接转化为Enumerable的一系列方法,最终在C#内部执行。...LINQ to Object的数据源总是实现IEnumerable(所以不如叫做LINQ to IEnumerable),相对的,LINQ to SQL的数据源总是实现IQueryable seq3 = seq.Where(o => o > 4).AsQueryable(); 模拟接口实现一个简单的LINQ to SQL 下面试图实现一个非常简单的查询提供器(即LINQ to xxx...在LINQ to SQL中lambda表达式首先被转化为表达式树,然后再转换为SQL语句。 我们试图实现一个可以将where这个lambda表达式翻译为SQL语句的查询提供器。

1.6K10

.NET深入解析LINQ框架(五:IQueryable、IQueryProvider接口详解)

那么在LINQ中来说,我们无法通过一个方法多次调用来产生我们想要的表达式树,一个Where查询表达式扩展方法可能不仅仅是被LINQ查询表达式所使用,还有可能被ORM的入口方法所使用,比如Update更新的时候就需要...Where给出更新的条件,Delete也同样如此。...2】.N层对象执行模型(纵横向对比链式扩展方法) 其实本来不打算加这一小节的,但是考虑到肯定有部分朋友不是很理解多个对象如何协调的去解决某类问题的。...详情可以参见本人的“NET深入解析LINQ框架(四:IQueryable、IQueryProvider接口详解)”一文; 3】.LINQ查询表达式和链式查询方法其实都是空壳子 LINQ的真正意图是在方便我们构建表达式树...ORM一直是我们比较喜欢去写的框架,这里就使用自定义的IQueryable来查询相应的对象实体。首先我们需要继承IQueryable接口来让LINQ能查询我们自己的数据上下文。

1K30

.NET深入解析LINQ框架(四:IQueryable、IQueryProvider接口详解)

条件判断不是重点,仅仅满足例子的需要。...我们在编写Linq语句的时候一般都是 where什么然后select 什么,至少连续两个扩展方法的映射调用,但是朋友你知道它内部是如何处理的吗?...其实这有点像是把大问题分解成多个小问题来解决,但是又不全是为了分解问题而这样设计,在链式查询中很多关键字在不同的查询上下文中都是公用的,比如where可以用在查询,也可以用在更新、删除。...两行代码都引用了Where方法,都需要拼接条件,但是 Where方法所产生的条件不会影响你之前的方法。分段执行的好处就在这里,最大粒度的脱耦才能最大程度的重用。...这个方法有一个参数,是条件表达式,并且这个方法扩展IQueryable接口,任何派生着都能直接使用。

1.4K11

C#内建接口:IQueryable

其主要用于 LINQ(Language Integrated Query)查询,它允许我们在编写类型安全的查询表达式时,将查询操作推迟到实际执行查询的时候,以便进行更有效的查询优化。...我们可以通过使用 LINQ 查询表达式或方法链式调用来构建查询,例如使用 Where、OrderBy、Select 等方法。...可组合性:IQueryable 查询具有良好的可组合性,我们可以根据需要在查询中添加和组合多个查询操作。这使得我们可以根据不同的条件动态构建查询,以及重复使用和组合查询逻辑。...() .Where(n => n % 2 == 0) .Select(n => n * 10); // 重新赋值...对象,针对这个查询对象,我们用 Where 方法筛选出偶数,再使用 Select 方法将每个偶数乘以 10取这样一个结果。

17410

linq to sql中慎用Where(Func predicate),小心被Linq给骗了!

; using System.Linq.Expressions; using CNTVS.LINQ; namespace TestLinq { class Program {...,找出F_Name中包含字母"J",F_Age大于20的记录,并且跳过第一个后,仅获取一条记录 注:PredicateBuilder是一个老外写的用于动态构造Expression表达式的工具类,在查询条件不确定...,需要动态创建时,非常有用,完整代码如下: 1 using System; 2 using System.Linq; 3 using System.Linq.Expressions; 4 5...(Expression))取数据,运行后输出结果跟上一种方式完全相同,而且这种方式可以在调用方法前动态创建需要的查询条件表达式,用法更灵活,但是我跟踪到的sql语句却是: SELECT [t0]....恳请园子里的哪位linq达人,能解释一二?

97350

Entity Framework 的一些性能建议

其实,我只要稍作调整,就能避免这个问题,但会LINQ语句难看一点: context.Post.Where(p => p.Id == postId).Select(p => p.Hits).FirstOrDefault...如果你只是想根据条件选择其中一些数据,而非全部的话,那ToList()以后再筛选,就是从内存里执行了,并不是把你的条件转换成sql的where语句去执行。...但这时,很不幸的是,where语句中的条件并不是转换为native sql去执行的,它是在内存中筛选的。这是一个比较阴的性能问题。...所以文章一开始我就建议大家多用SQL Profiler看看自己的LINQ是怎么执行的。 如果把返回类型换成IQueryable,那么你的where语句就可以转化为SQL执行。...当我们需要统计符合某条件的记录的条数时,我们希望SQL语句是SELECT COUNT(*) ... 这种形式的。

1.7K30

编写高质量代码改善C#程序的157个建议

本文主要学习记录以下内容:   建议29、区别LINQ查询中的IEnumerable和IQueryable   建议30、使用LINQ取代集合中的比较器和迭代器   建议31、在LINQ查询中避免不必要的迭代...建议29、区别LINQ查询中的IEnumerable和IQueryable   LINQ查询方法一共提供了两类扩展方法,在System.Linq命名空间下,有两个静态类:     Enumerable...LINQ to SQL引擎最终会将表达式树转化成为相应的SQL语句,然后在数据库中执行。   那么到底什么时候使用IQueryable,什么时候使用IEnumerable呢?...在LINQ to SQL的查询中,要尽量始终使用IQueryable。...第二种查询仅仅迭代1次是因为25正好放在list的首位,而查询条件是大于等于20.First方法实际完成的工作就是:搜索到满足条件的第一个元素,就从集合中返回。

91650

Asp.Net Core 扩展 Linq,简化自定义

前言 -为什么需要扩展 Linq 方法 Linq 在 .net 中使用是比较多的,而微软开发的 linq 相关函数无法满足实际项目开发中的需求,我们需要自己来扩展一些方法。...普通查询 对于 Linq 查询来说,Where 和 OrderBy 使用时需要直接点出来属性或者字段才行,如下所示: // 数据结构 public class ArticleTag { public...查询条件参数公共类型 先需要定义查询条件的公共参数,用于统一规范 namespace BlogSite.CommonLib.CommonEntity { /// //... Where(this IQueryable source, string propertyName, string content) { return source.Where..., IQueryable>(query, resultQuery); } } 这样通过 linq 就可以直接调用 UseCoditionFind 然后获取返回的 query,然后再

1.7K10

.NET深入解析LINQ框架(六:LINQ执行表达式)

之前我一直以为VS只负责将LINQ的表达式翻译成等价的扩展方法调用,后来发现VS为了满足我们在前期无法确定对象条件的情况下进行Where字句的拼接,允许我们在编写LINQ语句的时候带有逻辑判断表达式在里面...,这个功能对我们进行多条件组合查询时相当方便,不需要在进行IF、ELSE的多个判断,只需要顺其自然的在LINQ中的第一个表达式中进行判断就行了。...(truckModel.TRUCK_MODEL_CODE)); 如果有很多个查询条件,那么我们将要写很多这样的判断代码,即不方便也不美观。...(注:查看大图) 多条件之间的OR查询 尽管很多场合下我们都是使用Linq中的where关键字来拼接查询条件,但是有一种需求Linq查询确实满足不了我们,那就是多条件之间是OR的关系。...因为只要我们用Linq或者链式方法出来的写出来的SQL语句中的where条件后面将都是and关系,这个时候我们只能用链式方法来进行拆分才行。

1.3K10

在VS中调试LINQ(Lambda)

注意和前提 LinqLinq to object 对于Linq to object,只有集合对象是 IEnumerable 时,才能命中到Linq里的lambda表达式,IQueryable是不行的。...如果是IQueryable,此时就算在lambda表达式里打上断点,在代码执行时,断点会向上转移到整个语句上。...在 4 的基础上,对于IEnumerable,如果有多个条件,我们可以写在同一个Where()里,也可以拆开写在多个Where()里,不会影响效率的,因为不会生成多个暂存结果集。...(因为只有当前Linq语句满足条件后,才会进入下一个Linq语句。)...图示 下图是不填条件偷懒法:每个Linq语句的结果让下一个Linq语句输出,下一个Linq语句不要设置条件,只设置操作。所以图中是 OrderBy输出Where的执行结果。

4.5K30
领券