mysql中left join设置条件在on与where时的用法区别分析

作者:怀素真 时间:2024-01-12 15:05:52 

本文实例讲述了mysql中left join设置条件在on与where时的用法区别。分享给大家供大家参考,具体如下:

一、首先我们准备两张表来进行测试。


CREATE TABLE `a` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
`name` varchar(32) DEFAULT '' COMMENT '名称',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE `b` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
`a_id` int(11) DEFAULT '0' COMMENT 'a表ID',
`name` varchar(32) DEFAULT '' COMMENT '名称',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

两个表的数据如图所示:

mysql中left join设置条件在on与where时的用法区别分析

运行下面左连接查询:


select * from a left join b on a.id = b.a_id;

mysql中left join设置条件在on与where时的用法区别分析

我们分别在on和where后面加上条件,看看执行结果是否相同。


select * from a left join b on a.id = b.a_id and b.id > 3;

mysql中left join设置条件在on与where时的用法区别分析


select * from a left join b on a.id = b.a_id where b.id > 3;

mysql中left join设置条件在on与where时的用法区别分析

上面的两条语句,条件我们设置的是一样的都是b.id > 3,为什么显示结果不同。

sql语句查询的关键字顺序一般为 from > where > group by > having > order by

left join 在 from范围,on 条件会先对 left join 的右表进行筛选,筛选完后的结果 where 再进行筛选。

多个 left join 会生成一张临时表,on 条件是对 left join 右表进行条件过滤,where 条件针对最后生成的临时表进行过滤。

所以:

b.id > 3 的条件如果写在 on 后面,则是先对右边表(关联表)进行筛选,得出符合条件的行,然后主表 left join ,返回主表所有的行,右边表没匹配上的用 null 表示。

b.id > 3 的条件如果写在 where 后面,则是先主表 left join 右边表(关联表),返回所有的行,然后 where 条件再对结果进行筛选。

注意:on 后面的条件是针对右边的表(关联表),对主表没什么作用。


select * from a left join b on a.id = b.a_id and a.id > 3;

mysql中left join设置条件在on与where时的用法区别分析

我们在on 后面添加了对主表的条件 a.id > 3,不过主表的数据仍然全部显示出来了,但是影响了右边表(关联表)的显示。

如果想要对主表进行筛选,应该把条件写在where后。


select * from a left join b on a.id = b.a_id where a.id > 3;

mysql中left join设置条件在on与where时的用法区别分析

希望本文所述对大家MySQL数据库计有所帮助。

来源:https://www.cnblogs.com/jkko123/p/10148927.html

标签:mysql,left,join,on,where
0
投稿

猜你喜欢

  • python编程进阶之异常处理用法实例分析

    2023-01-27 16:39:24
  • mysql 5.7.21 安装配置方法图文教程(window)

    2024-01-28 05:04:12
  • 手把手带你走进Go语言之常量解析

    2024-05-08 10:44:38
  • MySQL replace into 语句浅析(一)

    2024-01-25 21:47:57
  • 基于Python中numpy数组的合并实例讲解

    2023-01-23 18:17:26
  • vue中提示$index is not defined错误的解决方式

    2024-04-27 16:16:51
  • Golang函数这些神操作你知道哪些

    2024-04-26 17:22:15
  • mac os10.12安装mysql5.7.18教程

    2024-01-19 14:08:27
  • python生成可执行exe控制Microsip自动填写号码并拨打功能

    2023-08-11 04:51:00
  • 教你用python提取txt文件中的特定信息并写入Excel

    2021-02-11 00:41:41
  • Python基于Serializer实现字段验证及序列化

    2023-07-19 21:50:36
  • python requests.get带header

    2022-07-28 20:50:40
  • Javascript实现数组中的元素上下移动

    2024-04-22 22:36:16
  • Python 动态导入对象,importlib.import_module()的使用方法

    2023-01-24 01:48:47
  • Python基于ImageAI实现图像识别详解

    2023-06-11 14:04:49
  • 巧用Javascript的逻辑运算符

    2024-04-16 09:47:42
  • python re正则表达式模块(Regular Expression)

    2021-01-26 20:22:26
  • 由Python编写的MySQL管理工具代码实例

    2024-01-13 23:52:32
  • Python的Flask框架中web表单的教程

    2023-05-17 06:11:06
  • python获取指定目录下所有文件名列表的方法

    2022-03-24 08:05:39
  • asp之家 网络编程 m.aspxhome.com