首页
学习
活动
专区
工具
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...INNER JOIN,这两种查询的结果相同。...但是语义上:JOIN - 描述两个表之间的关系,WHERE - 从结果集中删除行。这两种方法直接存在显著的语义上的差别,尽管两种方法对结果和性能都无影响,但是选择正确的语法将有助于代码更易于被阅读。...OUTER JOIN:如果使用的是 OUTER JOIN,可能会不同,比如上面的 SQL 改成 LEFT JOIN,并且连接条件失败,则查询条件放到 JOIN 子句仍将获得一行,但是如果放到 WHERE

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

    MySQL WHERE 子句

    昨天介绍了 MySQL 数据库使用 SELECT 语句来查询数据,同时也简单提到了MySQL WHERE 子句,今天详细讲解下。...语法 我们知道从 MySQL 表中使用 SELECT 语句来读取数据,如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中,WHERE 子句用于在 MySQL 中过滤查询结果,...WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。 参数介绍完成,再介绍下操作符。...通过以上实例,我们可以看出如果想在 MySQL 数据表中读取指定的数据,WHERE 子句是非常有用的。并且,使用主键来作为 WHERE 子句的条件查询是非常快速的。...如果给定的条件在表中没有任何匹配的记录,那么查询不会返回任何数据。 以上内容即为 MySQL 数据库使用 WHERE 子句来查询数据的简单讲解,下期再见。

    12310

    Mysql常用sql语句(8)- where 条件查询

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 条件查询应该是作为测试平时用到最多的关键字了!!...它可以用来指定查询条件,减少不必要的查询时间 where的语法格式 WHERE 查询条件 五种查询条件 比较运算符、逻辑运算符 between and 关键字 is null 关键字 in、exist...and、&&:所有查询条件均满足才会被查询出来 or、||:满足任意一个查询条件就会被查询出来 xor:满足其中一个条件,并且不满足另一个条件时,才会被查询出来 这里有个重点,当运算符混合使用时,需要关注它们的优先级...,具体可参考这篇博文:(后面补充) 单一条件的查询栗子 一般单一条件查询用的就是比较运算符 select * from yyTest where id = 1; select * from yyTest...yyTest where age < 20; select * from yyTest where age <= 20; 多条件的查询栗子 多条件的查询都需要使用逻辑运算符,下面的栗子比较简单不展开描述

    1.2K20

    开心档之MySQL WHERE 子句

    MySQL WHERE 子句 我们知道从 MySQL 表中使用 SQL SELECT 语句来读取数据。 如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中。...WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。 以下为操作符列表,可用于 WHERE 子句中。...如果我们想在 MySQL 数据表中读取指定的数据,WHERE 子句是非常有用的。 使用主键来作为 WHERE 子句的条件查询是非常快速的。...如果给定的条件在表中没有任何匹配的记录,那么查询不会返回任何数据。...从命令提示符中读取数据 我们将在SQL SELECT语句使用WHERE子句来读取MySQL数据表 kxdang_tbl 中的数据: 实例 以下实例将读取 kxdang_tbl 表中 kxdang_author

    1.1K20

    开心档之MySQL WHERE 子句

    MySQL WHERE 子句 我们知道从 MySQL 表中使用 SQL SELECT 语句来读取数据。 如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中。...WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。 以下为操作符列表,可用于 WHERE 子句中。...如果我们想在 MySQL 数据表中读取指定的数据,WHERE 子句是非常有用的。 使用主键来作为 WHERE 子句的条件查询是非常快速的。...如果给定的条件在表中没有任何匹配的记录,那么查询不会返回任何数据。...---- 从命令提示符中读取数据 我们将在SQL SELECT语句使用WHERE子句来读取MySQL数据表 kxdang_tbl 中的数据: 实例 以下实例将读取 kxdang_tbl 表中 kxdang_author

    99410

    MySQL JSON 数组用于 WHERE IN 子句

    1.目的 在某些情况下,我们希望在查询中使用 IN 子句来匹配 JSON 数组中的元素。 例如,我们有一个包含用户 ID 的 JSON 数组 [1, 2, 3],我们希望查询所有这些用户的信息。...JSON_TABLE 函数接受一个 JSON 数组和一个列名,将 JSON 数组的每个元素作为一行返回。然后我们可以将返回的结果作为子查询,并在主查询中使用 IN 子句。...然后我们将返回的结果作为子查询,并在主查询中使用 IN 子句来匹配用户的 ID。...注意 JSON_TABLE 是 MySQL 8.0 中的一个新函数,如果版本低于 8.0 将无法使用。...那么我们可以将 JSON 数组用于 WHERE IN 子句,转变成连表查询,使用 JSON_CONTAINS 用于 WHERE 条件,达到相同的效果。

    1.1K20

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

    图片WHERE、PREWHERE子句在ClickHouse中,WHERE和PREWHERE子句都用于筛选数据,但它们在查询中的使用有一些区别和注意事项。1....WHERE子句:WHERE子句在查询中是最后执行的,它作用于从表中读取的所有数据。WHERE子句可以包含任意条件,并且可以使用各种函数和操作符进行数据筛选。...WHERE子句可以使用索引来加速查询,优化性能。2. PREWHERE子句:PREWHERE子句在WHERE子句之前执行,它作用于从数据源读取的数据。...PREWHERE子句通常用于过滤数据源中不必要的行,以减少读取和处理的数据量,提升性能。PREWHERE子句只能包含简单的条件,不能使用聚合函数、多个列的条件判断等复杂操作。...WHERE和PREWHERE子句在ClickHouse的查询中都用于筛选数据,但WHERE子句是最后执行的,可包含复杂条件,能使用索引进行优化;而PREWHERE子句是在WHERE之前执行的,用于数据源的过滤

    1.8K61

    mysql left join on条件与where条件 统计报表查询方法

    mysql left join on条件与where条件 统计报表查询方法 1.确定数据数量,通过简化的sql查找符合条件的订单号列表 2.然后根据需求,添加单个的字段,在这个过程中会添加left join...左关联表查询 需要区分两种情况 2.1.可以唯一确定记录的, (SELECT t3.get_car_addr FROM `delivery_addr` t3 WHERE sub_order_no = (...= t1.order_no)) AS '送件地址', 2.2.查询条件会存在多条记录的,需要使用子查询,同时使用聚合函数等汇总。....source_code = '002') AS '扣款时间' 3.where过滤条件和left join on后的过滤条件的区别 3.1.where后面的过滤条件,比如是某个子表的条件,等于需要满足条件的才会查询出来...这样会不满足第一条:确定数据数量,这样查询的结果会变少。 原则是:where条件的选择数据数量的条件。而不是作为左关联的条件,除非需要满足左关联的表的条件才加上。

    6310

    Mysql连接查询时查询条件放在On之后和Where之后的区别

    where a.name = '一班' group by a.name  查询结果  原因 mysql 对于left join的采用类似嵌套循环的方式来进行从处理,以下面的语句为例: SELECT...b) { // 遍历完RT,发现lt在RT中没有有对应的行,则尝试用null补一行 IF P2(lt,NULL) {// 补上null后满足 where 过滤条件 t:=lt||NULL...问题一错误的原因:由于在where条件中对右表限制,导致数据缺失(四班应该有个为0的结果) 问题二错误的原因:由于在on条件中对左表限制,导致数据多余(其他班的结果也出来了,还是错的)。...on 后跟关联表(从表)的过滤条件,where 后跟主表或临时表的筛选条件(左连接为例,主表的数据都会查询到,所以临时表中必定包含主表所有的字段,需要给主表加什么筛选条件,直接给临时表加效果相同) 总结...通过上面的问题现象和分析,可以得出了结论:在left join语句中,左表过滤必须放where条件中,右表过滤必须放on条件中,这样结果才能不多不少,刚刚好。

    1.7K10

    MySQL 简单查询语句执行过程分析(四)WHERE 条件

    本文是 MySQL 简单查询语句执行过程分析 6 篇中的第 4 篇,第 1 ~ 3 篇请看这里: MySQL 简单查询语句执行过程分析(一)词法分析 & 语法分析 MySQL 简单查询语句执行过程分析(...二)查询准备阶段 MySQL 简单查询语句执行过程分析(三)从 InnoDB 读数据 今天我们分为 3 个部分来介绍,首先会看一下 where 条件在源码中的结构是什么样的,对 where 条件结构有了初步了解之后...MySQL 中多层 where 条件会形成一棵树状结构,每多一个层级,都需要额外的逻辑处理,执行效率上会有一点影响,所以在语法分析阶段,就会对 where 条件的树状结构层级进行简化,可以合并的层级就合并...示例 SQL 1: select * from t_recbuf where bit1 = 220 示例 SQL 1 中,用整数 220 作为 where 条件的值进行查询,server 层会把 char...,还请帮忙转发朋友圈,让更多的人看到,大家一起进步,谢谢 ^_^ 预告一下,下一篇要写的内容是 MySQL 简单查询语句执行过程分析(五)发送数据,敬请关注!

    2.4K30

    MySQL复杂where条件分析

    在《MySQL 常见语句加锁分析》一文中,我们详细讲解了 SQL 语句的加锁原理并具体分析了大部分的简单 SQL 语句,但是实际业务场景中 SQL 语句往往及其复杂,包含多个条件,此时就需要具体分析SQL...但是,今天我们讲一下具体 Where 语句的条件的拆分和使用,即复杂 Where 条件是如何生效的。...用何登成大神的原话,就是 给定一条SQL,where条件中的每个子条件,在SQL执行的过程中有分别起着什么样的作用?...MySQL 会根据索引选择性等指标选择其中一个索引来使用,而另外一个没有被使用的 Where 条件就被当做普通的过滤条件,一般称被用到的索引称为 Index Key,而作为普通过滤的条件则被称为 Table...对于这个场景,MySQL 依然使用 ISBN > 'N0004' AND ISBN 条件来确定 SQL 查询在索引中的连续位置,但是 Author = 'Tom' 可以用来直接过滤索引

    2.4K00

    用于 SELECT 和 WHERE 子句的函数

    和查询 expr 之间文本的相关相似的尺度。相关性是一个正的浮点型数字。零相关性意味着不相似。MATCH ... AGAINST() 可用于 MySQL 3.23.23 或更新的版本中。...注意,在一个 WHERE 子句中的 RAND() 将在每次 WHERE 执行时被重新计算。...这就是说,如果在一个单独的查询中多次引用了 NOW(),它只会给出值都是一个相同的时间。...如果 SELECT 语句从一个表中进行检索,没有检索其它的列,并且没有 WHERE 子句,那么 COUNT(*) 将被优化以便更快地返回值。...如果希望对结果中的值进行排序,可以使用 ORDER BY 子句。为了以倒序排序,可以在 ORDER BY 子句中用于排序的列名后添加一个 DESC (递减 descending) 关键词。

    4.8K30

    软件测试|MySQL WHERE条件查询详解:筛选出需要的数据

    简介在数据库中,我们常常需要从表中筛选出符合特定条件的数据,以便满足业务需求或获取有用的信息。MySQL提供了WHERE条件查询,使我们能够轻松地筛选数据。...本文将详细介绍MySQL WHERE条件查询的用法和示例,帮助大家更好地理解和应用这一功能。...通过使用比较运算符、逻辑运算符和IN子句等,我们可以构建复杂的查询条件来获取满足特定条件的数据。...通过本文的示例,我们希望大家对MySQL WHERE条件查询有了更深入的了解,并能在实际应用中灵活运用该功能。...无论是进行简单的条件筛选还是复杂的多条件组合查询,MySQL的WHERE条件查询都能帮助大家轻松实现数据的精准筛选。

    55430

    MySQL数据插入INSERT INTO与条件查询WHERE的基本用法(二)

    本节课先向大家介绍MySQL数据插入insert into与where条件查询的基本用法。 首先,MySQL的书写顺序和执行顺序分别如下。...1、where 单条件查询 【任务1】通过mysql条件查询语句,在titanic表中查找出年龄等于30岁的乘客。...2、where多条件查询 【任务2】通过mysql条件查询语句,在titanic表中查找出年龄等于30岁且性别为男性的所有乘客。可以通过如下查询语句实现。...【任务3】通过mysql条件查询语句,在titanic表中查找出年龄等于30岁或性别为男性的所有乘客。可以通过如下查询语句实现。...同时MySQL数据库是通过where进行条件筛选的,where后紧跟条件,通常与and/or同时使用。

    4.4K30

    HAVNG 子句 和 WHERE 的异同点?

    HAVING 子句和 WHERE 子句在 SQL 查询中都用于过滤数据,但它们的作用范围和使用场景有所不同。以下是它们的主要异同点:相同点过滤功能:两者都可以用于过滤查询结果。...条件表达式:都可以使用条件表达式来指定过滤条件。不同点作用对象:WHERE 子句:用于在聚合操作之前过滤行。它在选择哪些行进入聚合函数之前进行过滤。HAVING 子句:用于在聚合操作之后过滤行。...使用场景:WHERE 子句:通常用于过滤单个行的数据,不涉及聚合函数。HAVING 子句:通常用于过滤聚合后的结果,可以包含聚合函数(如 COUNT, SUM, AVG 等)。...;在这个查询中,WHERE 子句在聚合之前过滤掉 amount 小于 100 的行。...amount) > 500;在这个查询中,HAVING 子句在聚合之后过滤掉 total_amount 小于 500 的客户。

    5710

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

    有查询条件就查询,多个查询条件,只要有查询,就增加一个查询条件 一、TP5.1版本 TP运算符 SQL运算符 例子 实际查询条件 eq = $map['id'] = array('eq',100); 等效于...in',array('1','5','8')); exp 表达式 上表中的 exp 不是一个运算符,而是一个综合表达式以支持更复杂的条件设置。...exp 不仅用于 where 条件,也可以用于数据更新,如: 官方查询语法:https://www.kancloud.cn/manual/thinkphp5/135182 版本 新增功能 5.0.9 比较运算增加闭包子查询支持...5.0.4 支持对同一个字段多次调用查询方法 查询表达式支持大部分的SQL查询语法,也是ThinkPHP查询语言的精髓,查询表达式的使用格式: where('字段名','表达式','查询条件');...whereOr('字段名','表达式','查询条件'); 表达式不分大小写,支持的查询表达式有下面几种,分别表示的含义是: 表达式 含义 EQ、= 等于(=) NEQ、 不等于() GT、> 大于

    6.3K21
    领券