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

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

我们再写 SQL 的时候,最常碰到一个问题就是,把查询条件放到 JOIN 子句和放到 WHERE 子句有什么不同呢?...比如: 查询条件放到 JOIN 语句: SELECT SQL_CALC_FOUND_ROWS wp_posts.ID FROM wp_posts JOIN wp_skus sku ON sku.post_id...'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

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

    sql中的 where 、group by 和 having 用法解析

    --sql中的 where 、group by 和 having 用法解析 --如果要用到group by 一般用到的就是“每这个字” 例如说明现在有一个这样的表:每个部门有多少人 就要用到分组的技术...有些数据库例外,如oracle 当同时含有 where 子句、group by 子句 、having 子句及聚集函数时,执行顺序如下: 执行where子句查找符合条件的数据; 使用group...//进行分组显示,并且按照where条件之后计数,在根据having子句筛选分组 SQL> select sno,count(*) from sc where grade>=90 group...) > (select avg(grade) from sc where sno=3); –sql中的 where 、group by 和 having 用法解析 –如果要用到group by 一般用到的就是...//进行分组显示,并且按照where条件之后计数,在根据having子句筛选分组 SQL> select sno,count(*) from sc where grade>=90 group by

    12.9K30

    ClickHouse中,WHERE、PREWHERE子句和SELECT子句的使用

    图片WHERE、PREWHERE子句在ClickHouse中,WHERE和PREWHERE子句都用于筛选数据,但它们在查询中的使用有一些区别和注意事项。1....WHERE子句:WHERE子句在查询中是最后执行的,它作用于从表中读取的所有数据。WHERE子句可以包含任意条件,并且可以使用各种函数和操作符进行数据筛选。...PREWHERE子句通常用于过滤数据源中不必要的行,以减少读取和处理的数据量,提升性能。PREWHERE子句只能包含简单的条件,不能使用聚合函数、多个列的条件判断等复杂操作。...=、等)和逻辑运算符进行条件过滤。分组:支持使用GROUP BY子句对结果进行分组。可以指定一个或多个列进行分组。限制:支持使用LIMIT子句限制结果中的行数。可以指定要返回的最大行数。...然后,它进行了一个条件过滤,在column1大于10的行中进行计数(COUNT(*))。接下来,使用GROUP BY子句对column1进行分组,并使用HAVING子句对计数进行条件过滤。

    1.8K61

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

    最近遇到相关业务,想揪一下sql的中的left join 或者right join 或者inner join 中的 on和where的区别,想了解这个首先我们要了解两个基础的知识。...1.join的三种连接方式的区别: left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录...和 where 是没有区别的 下面我们来执行sql语句看看 left join select a....,并且如果右表用了where还是两个表都会取交集,进行过滤。...类似:如果是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中返回结果一致。...结论:Left Join时过滤条件放在on和where中返回结果不一致。 原因分析 可以这么理解,当两张表在Left Join时,会生成一张连接临时表,然后再将这张连接临时表返回给用户。...在Where的情况下,是在临时表生成好以后起作用,在对临时表进行过滤。此时,只要条件不为真的行,全部都过滤掉了。 — 完 —

    3.5K10

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

    where 条件中的每个子条件,在 SQL 执行的过程中有分别起着什么样的作用 ? 前提准备   正式开讲之前了,我们先来回顾一些内容   SQL 执行流程 ?     ...这是 MySQL 数据库中 SQL 的执行流程,其他数据库应该类似   关系型数据库中的数据组织     关系型数据库中,数据组织涉及到两个最基本的结构:表与索引。...= 2 ,因为索引第一列只包含 >=、两个条件,因此第一列跳过,将余下的 c、d 两列加入到 Index Filter 中,提取结束   Table Filter     这个就比较简单了,where...中不能被索引过滤的条件都归为此中;提取规则:所有不属于索引列的查询条件,均归为 Table Filter 之中     针对 SQL:select * from tbl_test where b >=...大家可以先去了解下,我们下篇详细讲解 参考 SQL中的where条件,在数据库中提取与应用浅析 MySQL的索引 MySQL的server层和存储引擎层是如何交互的

    1.9K10

    软件测试|SQL指定查询条件,WHERE的使用

    前言使用 SQL 从单个表或者多表联合查询数据时,可以使用 WHERE 子句指定查询条件。当给定查询条件时,只有满足条件的数据才会被返回。建议您使用 WHERE 子句来过滤记录,以获取必要的结果集。...WHERE 子句不仅可以用在 SELECT 语句中,还可以用在 UPDATE、DELETE 等语句中,我们将在后续进行介绍。...语法WHERE 子句用于 SELECT 语句时的基本语法如下:SELECT column1, column2, columnNFROM table_nameWHERE condition注:可以在 condition...,并且返回name,age两个字段,代码如下:SELECT name, ageFROM playerWHERE age > 30;该语句将得到如下的结果:+--------+-----+|name...中WHERE子句的使用,后续我们将继续介绍SQL的使用。

    98120

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

    根据SQL,固定了索引的查询范围[(2,2,2),(8,8,8))之后,此索引范围中并不是每条记录都是满⾜where查询条件的。例如:(3,1,1)不满⾜c > 1的约束;(6,4,4)不满⾜d !...在理解以上的问题解答的基础上,做⼀个抽象,可总结出⼀套放置于所有SQL语句⽽皆准的where查询条件的提取规则: 所有SQL的where条件,均可归纳为3⼤类 • Index Key (First Key...在上⾯的SQL⽤例中,(3,1,1),(6,4,4)均属于范围中,但是又均不满⾜SQL的查询条件。...;若where条件为 >=、>、的⼏种,则跳过索引第⼀列,将其余where条件中索引相关列全部加⼊到Index Filter之中;若索引第⼀列的where条件包含 =、>=、>、的⽤例SQL,索引第⼀列只包含 >=、两个条件,因此第⼀列可跳过,将余下的c、d两列加⼊到Index Filter中。因此获得的Index Filter为 c > 1 and d !

    2.3K10

    数据库中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...left join 会把左表中有on过滤后的临时表中没有的添加进来,右表用null填充 right会把右表中有on过滤后的临时表中没有的添加进来,左表用null填充 故将王五添加进来,并且右表填充null...执行顺序之from>on>join>where 生成笛卡尔积 执行on子句过滤 执行join子句回填数据 left join 回填被on过滤掉的左表数据,右表用null填充 right...join 回填被on过滤掉的右表的数据,左表用null填充 inner join 不处理 完整的sql执行顺序 from>on>join>where>group by>having>select

    8610

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

    基于以上测试结果,我萌生了这样一个想法,能不能通过手动调整where中的过滤条件顺序,来让url和time的过滤先执行,最后再对info使用udf进行判断?...我们使用explain查看sql的执行计划,如下所示: 通过执行计划,我们可以看到,where中的一系列过滤条件都被转换成了相应的predicates,由于day是时间分区列,可以直接进行过滤,因此不在这个...从图中我们可以看到,三个过滤条件的执行顺序依次是:info->time->url,使用udf的过滤条件被放到了第一个位置,这不是我们想要的结果,因此,我们修改SQL中的where条件顺序,如下所示: select...其中有一个whereClause_成员,就是where条件中的各个过滤条件经过语法解析之后生成的结果,是一个Expr类,其UML图如下所示: 最终,where中的各个过滤条件就会被转换成对应的Predicate...小结 通过以上的代码学习,我们终于知道了:为什么最开始的SQL,我们调整了where中过滤条件的顺序,并不能改变执行计划中的predicates顺序。

    1.7K20

    SQL - where条件里的!=会过滤值为null的数据

    =会过滤值为null的数据 在测试数据时忽然发现,使用如下的SQL是无法查询到对应column为null的数据的: 1 select * from test where name !...=换成也是一样的结果,这可能是因为在数据库里null是一个特殊值,有自己的判断标准,如果想要把null的数据也一起搜索出来,需要额外加上条件,如下: 1 select * from test where...= 'Lewis' or name is null; 虽然这只是个小知识点,不过还是值得记录注意下,以免日后在开发中犯小错误。...null值的比较 这里另外说下SQL里null值的比较,任何与null值的比较结果,最后都会变成null,以PostgreSQL为例,如下: 1 2 3 4 select null !...参考链接 Sql 中 不等于'‘与 NULL 警告 本文最后更新于 November 12, 2019,文中内容可能已过时,请谨慎使用。

    2.1K40

    图解sql中的where和on的区别

    经常会有读者有疑问,sql中关联条件是放where后面好,还是on后面好?今天就通过图形的方式给大家来解决这个问题。 之前两章我们通过图解SQL的执行顺序和JOIN的原理知道了这两步的执行过程。...和WHERE都是过滤筛选条件的,那么能不能将WHERE后面的条件 a.城市='广州' 放在 ON条件后面呢?...我们还是以上一章的例题来讲解: 因为在sql的内连接阶段,左表(a)和右表(b)通过笛卡尔积生成的虚表VT-A1, VT-A1 在经过内连接后会将虚表VT-A1中符合条件 (a.CustomerID=b.CustomerID...这是因为在执行sql左连接的时候,是先执行的ON后面的所有条件。...结论 1、对于内连接(inner join),sql过滤条件放在where或者on后面没有区别 2、对于左右连接(left/right join),sql过滤条件放在where或者on后面有很大的区别。

    16210

    mysql中将where条件中过滤掉的group by分组后查询无数据的行进行补0

    背景 mysql经常会用到group By来进行分组查询,但也经常会遇到一个问题,就是当有where条件时,被where条件过滤的数据不显示了。...例如我有一组数据: 我想查询创建时间大于某一范围的spu的分组下的sku的数量 正常的sql查出的话,假如不存在相关记录 SELECT product_id , count( *) count FROM...product_sku WHERE create_time >= #{param} AND product_id in (1,2,3,4,5) GROUP BY product_id 结果查不到任何记录...即使没有数据,也想让count显示出0而不是空的效果 因此,我们想实现,即使没有数据,也想让count显示出0而不是空的效果; 解决方案:构建一个包含所有productId的结果集;然后和我们本来的sql...product_id in (1,2,3,4,5) GROUP BY product_id ) AS b ON a.product_id = b.product_id 本篇文章如有帮助到您,请给「翎野君

    22910

    sql中的if条件语句的用法

    IF 表达式 IF( a, b, c) a的值为TRUE,则返回值为 b a的值为FALSE,则返回值为 c 如下: SELECT IF(TRUE,1,2); -> 1 SELECT IF(FALSE...,1,2); -> 2 SELECT IF(STRCMP("123","234"),"不相等","相等"); -> 不相等 举个例子: 查找出年龄大于18的学生,如果是男生的话,就要标注为栋梁,否则是未成年...select *,if(sex='man','栋梁','未成年') as student_can_be from class_1 where age>18 把salary表中的女改成男,男改成女:...返回第二个参数 b SELECT IFNULL(NULL,"11"); -> 11 SELECT IFNULL("00","11"); -> 00 NULLIF 表达式 NULLIF(a,b):如果两个参数相等则返回...NULL,否则返回第一个参数的值a mysql> select nullif(1,1),nullif(123,234); +-------------+-----------------+ | nullif

    4.8K10

    SQL中Group By 的常见使用方法.

    3,实例说明 示例1 SQL语句如下: select category, sum(count) as 数量之和 from groupbyDemo group by category 结果如下: ?...说明, 这里加的 查询summary 会显示数据的第一条记录.  4,Group By与聚合函数 常用的聚合函数: count, sum, avg, max, min 示例1 SQL语句如下: SELECT...5, Having与Where的区别 (1)where 子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,where条件中不能包含聚组函数,使用where条件过滤出特定的行...(2)having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having 条件过滤出特定的组,也可以使用多个分组标准进行分组。...示例2 SQL语句: SELECT category, SUM(COUNT)FROM groupByDemo WHERE COUNT > 10 GROUP BY category HAVING SUM(

    2K130
    领券