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

SQL 查询条件放到 JOIN 子句与 WHERE 子句的差别

我们再写 SQL 的时候,最常碰到一个问题就是,把查询条件放到 JOIN 子句和放到 WHERE 子句有什么不同呢?...'publish' ORDER BY sku.price DESC, wp_posts.post_date DESC LIMIT 0, 10 查询条件放到 WHERE 语句: SELECT SQL_CALC_FOUND_ROWS...但是语义上:JOIN - 描述两个表之间的关系,WHERE - 从结果集中删除行。这两种方法直接存在显著的语义上的差别,尽管两种方法对结果和性能都无影响,但是选择正确的语法将有助于代码更易于被阅读。...OUTER JOIN:如果使用的是 OUTER JOIN,可能会不同,比如上面的 SQL 改成 LEFT JOIN,并且连接条件失败,则查询条件放到 JOIN 子句仍将获得一行,但是如果放到 WHERE...子句,则它将被过滤掉,因为 NULL 不等于 1。

2.4K20

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.6K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数据库中on条件与where条件的区别

    数据库中on条件与where条件的区别 有需要互关的小伙伴,关注一下,有关必回关,争取今年认证早日拿到博客专家 标签:数据库 mysql> SELECT e.empno,ename,e.deptno,...条件 -- 因为e.is_deleted = 0再过滤条件中,所以不会出现再结果集中 mysql> SELECT e.empno,ename,e.deptno as edeptno,e.is_deleted...将被on条件过滤掉的李四和王五加回来,右表填充null +-------+-------+---------+------------+--------+---------+ | empno | ename...生成笛卡尔积 执行on子句过滤 执行join子句回填数据 left join 回填被on过滤掉的左表数据,右表用null填充 right join 回填被on过滤掉的右表的数据,左表用...null填充 inner join 不处理 完整的sql执行顺序 from>on>join>where>group by>having>select>distinct>order by>limit

    8610

    函数或条件子句的占位符

    推荐在遍历原数据集合时根据条件创建一个新的数据集合,遴选公务员而这正是Python语言中for语句的强大之处。 Python还支持pass 语句,该语句不执行任何操作。...该语句可以用作函数或条件子句的占位符,以便让开发者聚焦更抽象的层次。...http://www.gongxuanwang.com/ 遴选公务员函数定义时形参的位置次序依次传入参数,也可以按关键字(形参名=形参值)的方式传入参数(无需按函数定义时形参的顺序传递),还可以两者混用...,但关键字传参必须在位置传参之后: 也可以按关键字(形参名=形参值)的方式传入参数(无需按函数定义时形参的顺序传递),还可以两者混用。...、列表中的值按位置传参的方式传入函数,可以通过**将字典中的值按关键字传参的方式传入函数:http://lx.gongxuanwang.com/

    81530

    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('字段名','表达式','查询条件');

    6.3K21

    浅析Impala中的where条件执行顺序

    基于以上测试结果,我萌生了这样一个想法,能不能通过手动调整where中的过滤条件顺序,来让url和time的过滤先执行,最后再对info使用udf进行判断?...从图中我们可以看到,三个过滤条件的执行顺序依次是:info->time->url,使用udf的过滤条件被放到了第一个位置,这不是我们想要的结果,因此,我们修改SQL中的where条件顺序,如下所示: select...其中有一个whereClause_成员,就是where条件中的各个过滤条件经过语法解析之后生成的结果,是一个Expr类,其UML图如下所示: 最终,where中的各个过滤条件就会被转换成对应的Predicate...从图中我们看到这个树按照从左到右,从上到下的顺序,与SQL语句中的where过滤条件顺序是一致,所以说相关的predicate顺序调整不在这个地方。我们需要继续往后跟踪代码。...小结 通过以上的代码学习,我们终于知道了:为什么最开始的SQL,我们调整了where中过滤条件的顺序,并不能改变执行计划中的predicates顺序。

    1.7K20

    left join-on-and 与 left join-on-where 和 inner join on 加条件和where加条件的区别

    摘要 关于这两种写法的重要知识点摘要如下: left-join 时,即使有相同的查询条件,二者的查询结果集也不同,原因是优先级导致的,on 的优先级比 where 高 on-and 是进行韦恩运算连接生成临时表时使用的条件...where则是在生成临时表之后使用的条件,此时已经不管是否使用了left join了,只要条件不为真的行,全部过滤掉。 在多表查询时,on 比 where 更早起作用。...系统首先根据各个表之间的联接条件,把多个表合成一个临时表后,再由 where 进行过滤,然后再计算,计算完后再由 having 进行过滤。...对于 join 参与的表的关联操作,如果需要不满足连接条件的行也在我们的查询范围内的话,我们就必需把连接条件放在 on 后面,而不能放在 where 后面,如果我们把连接条件放在了 where 后面,那么所有的...,on-where 写法会先对右表做1个条件的过滤,然后对 join 后的结果再执行1个条件的过滤 由于 on 优先级比 where 更高,执行时机会更早,因此,理论上来说 on-and 写法比 on-where

    2.6K30

    mysql的where条件后加case_recommend

    大家好,又见面了,我是你们的朋友全栈君。 背景:数据库用的Oracle; 报表用的是【FineReport】,之前没用过,被临时授命解决问题,所以大概了解了一下。...里面应该是集成了excel插件,报表样式如下: 今天在项目中遇到一个这样的场景: A为汇总页面,显示的是按医院分组统计出来的一些数据,效果如下图 图中每一列都能下钻到另一个页面,医院名称和起始时间都作为参数传送...前期因为某一些需求,有一家医院出现了两个不同的名称,所以将其中一个名称的数据统计到了另一个名称下。而【检查数】这一列下钻后的数据,恰恰是被合并的名称下的数据,所以下钻后就查不到数据了。...但我觉得这样的客户体验不好,所以想到了能不能在where中增加case when。所以在网上查了一下,果然是可行的。...所以就将下钻后的查询条件修改成了下图这样: 之前的条件为:study.HospitalName=’${xxxx}’。 这里记录一下,为以后需要的同行铺一下路。

    1.8K30

    MySQL存储过程where条件执行失败的问题

    跟踪了半小时,发现是数据库的数据出错了,玩家下线保存角色数据的时候,居然将数据库内所有角色的数据都改了,然后赶紧去看存储过程,但是看不出存储过程的错误。...from pet where condition; if count > 0 then update pet set key1 = value1, ......,后来突然想到一个问题,是不是参数命名问题,改了一些参数命名,某一次突然正确了,经过比较发现,原来where后面作为条件的变量名不能和字段名相同,而且这里是不区分大小写的。...但是作为update和insert into的参数确是可以的,mysql真的很坑爹呀。...最后回到最开始的问题,where后面是 RoleID = roleID; 所以执行失败了,只需要把参数roleID改下名,不和字段名RoleID同名即可。

    2.3K20

    MySQL数据库,SQL的where条件提取

    在确定了索引中最终能够过滤掉的条件之后,还有哪些条件是索引⽆法过滤的? 此问题的答案显⽽易见,e != ‘a’这个查询条件,⽆法在索引idxt1bcd上进⾏过滤,因为索引并未包含e列。...由于⼀个范围,⾄少包含⼀个起始与⼀个终⽌,因此Index Key也被拆分为Index First Key和Index Last Key,分别⽤于定位索引查找的起始,以及索引查询的终⽌条件。...;若where条件为 >=、>、的⼏种,则跳过索引第⼀列,将其余where条件中索引相关列全部加⼊到Index Filter之中;若索引第⼀列的where条件包含 =、>=、>、的条件,则将此条件以及其余where条件中索引相关列全部加⼊到Index Filter之中;若第⼀列不包含查询条件,则将所有索引相关条件均加⼊到Index Filter之中。...针对上⾯的⽤例SQL,索引第⼀列只包含 >=、条件,因此第⼀列可跳过,将余下的c、d两列加⼊到Index Filter中。因此获得的Index Filter为 c > 1 and d !

    2.3K10

    神奇的 SQL 之 WHERE 条件的提取与应用

    = 'a' 无法在索引 idx_bcd 上进行过滤,因为索引并未包含 e 列;e 列只在堆表上存在,所以需要将已经满足索引查询条件的记录回表,取出对应的完整数据记录,然后看该数据记录中 e 列值是否满足...,被称之为Index Key;由于一个范围,至少包含一个起始条件与一个终止条件,因此 Index Key 也被拆分为 Index First Key 和 Index Last Key,分别用于定位索引查找的起始点以终止点...>、的几种,则跳过索引第一列,将其余 where 条件中索引相关列全部加入到 Index Filter 之中;若索引第一列的 where 条件包含 =、>=、>、的条件,则将此条件以及其余...where 条件中索引相关列全部加入到 Index Filter 之中;若第一列不包含查询条件,则将所有索引相关条件均加入到 Index Filter之中     针对 SQL:select * from...= 2 ,因为索引第一列只包含 >=、条件,因此第一列跳过,将余下的 c、d 两列加入到 Index Filter 中,提取结束   Table Filter     这个就比较简单了,where

    1.9K10

    TP5 where数组查询(模糊查询)(有多个查询条件) when「建议收藏」

    ) ->field('id,type,score,sex') ->select(); TP6 and条件再加多个or条件 $whereOr[] = [['uid', '=', $uid]]; $whereOr..., 多个查询条件,只要有查询,就增加一个查询条件 一、TP5.1版本 模糊查询 $where[] = ['title','like',"%"....` LIKE 'thinkphp%' AND `title` LIKE '%thinkphp' AND `id` > 0 ) AND `status` = '1' 如果使用下面的多个条件组合 $map1...,也是ThinkPHP查询语言的精髓,查询表达式的使用格式: where('字段名','表达式','查询条件'); whereOr('字段名','表达式','查询条件'); 表达式不分大小写,支持的查询表达式有下面几种...('id','>=',100); 表示的查询条件就是 id >= 100 LT:小于(<) 例如: where('id','lt',100); where('id','<',100); 表示的查询条件就是

    6.8K40

    sql中的过滤条件放在on和where的区别

    最近遇到相关业务,想揪一下sql的中的left join 或者right join 或者inner join 中的 on和where的区别,想了解这个首先我们要了解两个基础的知识。...1.join的三种连接方式的区别: left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录...笛卡尔积:两个[集合]*X*和*Y*的笛卡尓积(Cartesian product),又称[直积],表示为*X* × *Y*,第一个对象是*X*的成员而第二个对象是*Y*的所有可能[有序对]的其中一个成员...12 | +----+--------+------+------+--------+ 5 rows in set (0.00 sec) 结论:left join时进行笛卡尔积之后on后面的条件只对右表有效...类似:如果是right join的话 right join时进行笛卡尔积之后on后面的条件只对左表有效 ,并且如果左表用了where还是两个表都会取交集,进行过滤。 有对结论有疑问者,欢迎讨论~~~

    3.8K10

    SQL中JOIN时条件放在Where和On的区别

    背景 SQL中JOIN子句是用于把来自两个或多个表的数据连接起来,在这个过程中可能会添加一些过滤条件。昨天有小伙伴问,如下图的这两种SQL写法查询结果是否会一样?(好像这是某一年阿里的面试题) ?...结果验证 将上面的两个表Inner Join和Left Join,过滤条件分别放在on和where中。...结论:Inner Join时过滤条件放在on和where中返回结果一致。...在On的情况下,是在生成临时表时起作用,但由于Left Join的性质,就是他不管On里面的过滤条件是否为真,都会返回左表里的记录。对于不满足条件的记录,右表字段全部是NULL。...在Where的情况下,是在临时表生成好以后起作用,在对临时表进行过滤。此时,只要条件不为真的行,全部都过滤掉了。 — 完 —

    3.5K10

    动态Linq的逻辑与和逻辑或的条件查询

    最近在做一个数据检索的工作,对一个数据库中的宽表进行多个条件的检索。为了简单方便快捷的完成这个功能,我使用LINQ to SQL+ReportView的方式来完成。...首先需要做的是一个查询界面和写一个数据库查询方法。用户在输入框中输入多个指标,将根据指标的格式生成LINQ的Where语句。...那么查询字符串就变成了: (北京 上海 重庆)(2000 2010) 人口 这样括号之间是与的关系,括号内的内容是或的关系。 但是真正的难点是如何用LINQ来实现动态的或查询。...我第一想到的是Dynamic LINQ(具体参见:这里),这个在之前的项目中用过,特别强大,但是在这里用起来不是很方便,所以又想自己实现一套动态OR查询的方法,结果由于时间和能力有限,也没有做出来,最后终于找到一个很好的类库...                }                 data = data.Where(predicate);//将最后的predicate传入Where函数,相当于是对括号之间进行逻辑与查询

    1.6K10

    【转】MySQL 多表Join条件在ON AND 和 Where的写法差异

    在MySQL中,多表Join是一种常见的操作,它允许从多个表中根据相关联的列,来组合提取数据。MySQL中多表关联也是支持,多种方式.。比如内连接,左链接,右链接,笛卡尔积等方式。...示例分析:两张表s1 和 s2,LEFT JOIN下s1.name IN(‘a’,‘c’)条件使用在AND 和 WHERE 下得到的结果集不一样。...,它不管ON中的条件是否为真,都会返回左边表中的记录。...AND 的条件只在右表中进行是否为真的条件显示2. WHERE条件是在临时表生成好后,再对临时表进行过滤的条件。...这时已经没有LEFT JOIN的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。在MySQL当中,除了INNER JOIN外,使用JOIN类型时,一定要把ON 和 WHERE条件正确使用。

    25910
    领券