mysql中的join和where优先级顺序解读

 更新时间:2023年03月20日 10:50:30   作者:所谓永恒  
这篇文章主要介绍了mysql中的join和where优先级顺序解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

mysql 的 join 和 where 优先级

定义

join功能

  • inner join(内连接,或等值连接) : 获取两个表中字段匹配关系的记录。
  • left join (左连接) : 获取左表所有记录,即使右表没有对应匹配的记录。
  • right join (右连接) : 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。

where

where 是 mysql 语句的查询条件

测试数据表

  • 表 a1
xy
110
220
330
  • 表 a2
xy
10100
20200
20300
create table if not exists `a1`(
    `x` int(10),
    `y` int(10)
);

create table if not exists `a2`(
    `y` int(10),
    `z` int(10)
)

查询 sql 及结果

正常左连接

select * from a1 left join a2 on a1.y = a2.y;
xyyz
11010100
22020200
22020300
330NULLNULL

左连情况下, 由于左边a1.y = 30在右表无数据所以右表数据 (y,z)为 NULL

左连 on && and

select * from a1 left join a2 on a1.y = a2.y and a2.y = 10;
xyyz
11010100
220NULLNULL
330NULLNULL

由于是左连, 所以判断 (a1.y = a2.y && a2.y = 10) 只能筛选出(10, 100)与左边匹配, 所以后面均为 NULL.

即实际优先级是

select * from (a1 left join a2 on a1.y = a2.y and a2.y = 10)

左连 on && where

select * from a1 left join a2 on a1.y = a2.y where a2.y = 10;
xyyz
11010100

只有一条数据, 因此可判断其优先级为

select * from (a1 left join a2 on a1.y = a2.y) where a2.y = 10​​​​​​​

也就是说 会先左连生成临时表, 然后再在整体表上进行 where 查询.

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL 驱动中虚引用 GC 耗时优化与源码分析

    MySQL 驱动中虚引用 GC 耗时优化与源码分析

    这篇文章主要为大家介绍了MySQL 驱动中虚引用 GC 耗时优化与源码分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • 深入理解MySQL中MVCC与BufferPool缓存机制

    深入理解MySQL中MVCC与BufferPool缓存机制

    这篇文章主要介绍了深入理解MySQL中MVCC与BufferPool缓存机制,MySQL默认RR隔离级别就是通过该机制来保证的MVCC,更多主题相关内容,需要的可以参考下面文章内容介绍
    2022-05-05
  • mysql错误代码error2003的问题及解决

    mysql错误代码error2003的问题及解决

    这篇文章主要介绍了mysql错误代码error2003的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • Mysql行与列的多种转换(行转列,列转行,多列转一行,一行转多列)

    Mysql行与列的多种转换(行转列,列转行,多列转一行,一行转多列)

    在MySQL中,行转列和列转行都是非常有用的操作,本文就来介绍一下Mysql行与列的多种转换,主要包括行转列,列转行,多列转一行,一行转多列,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • MySQL优化之缓存优化(续)

    MySQL优化之缓存优化(续)

    本文是MySQL优化系列文章的第一篇缓存优化的续篇,为大家更为详细的介绍缓存优化的方方面面,希望大家能够喜欢
    2017-03-03
  • MySQL5.6基于GTID的主从复制

    MySQL5.6基于GTID的主从复制

    这篇文章主要介绍了MySQL5.6基于GTID的主从复制的相关资料,需要的朋友可以参考下
    2016-02-02
  • Linux自动备份MySQL数据库脚本代码

    Linux自动备份MySQL数据库脚本代码

    下面这段Linux的Shell脚本用于每日自动备份MySQL数据库,可通过Linux的crontab每天定时执行
    2013-11-11
  • MySQL数据库查询性能优化的4个技巧干货

    MySQL数据库查询性能优化的4个技巧干货

    这篇文章主要为大家介绍了MySQL数据库查询性能优化的4个技巧干货详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • MySQL变量原理及应用实例

    MySQL变量原理及应用实例

    这篇文章主要介绍了MySQL变量原理及应用实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • 初始化MySQL用户(删除匿名用户)

    初始化MySQL用户(删除匿名用户)

    安装完MySQL后,系统默认会创建一个不需要密码的root用户,和一个无用户名无密码的匿名用户(Anonymous Account)。进行下面的初始化操作以合理授权,增强安全
    2016-01-01

最新评论