神奇的 SQL 之 联表细节 → MySQL JOIN 的执行过程(一)

  我:嗨,老板娘,有冰红茶没
  老板娘:有
  我:多少钱一瓶
  老板娘:3块
  我:给我来一瓶,给,3块
  老板娘:来,你的冰红茶
  我:玩呐,我要冰红茶,你给我个瓶盖干哈?
  老板娘:这是再来一瓶,我家卖完了,你去隔壁家换一下

神奇的 SQL 之 联表细节 → MySQL JOIN 的执行过程(一)

问题背景

  对于 MySQLJOIN,不知道大家有没有去想过他的执行流程,亦或有没有怀疑过自己的理解(自信满满的自我认为!);如果大家不知道怎么检验,可以试着回答如下的问题

  驱动表的选择

    MySQL 会如何选择驱动表,按从左至右的顺序选择第一个?

  多表连接的顺序

    假设我们有 3 张表:A、B、C,和如下 SQL

-- 伪 SQL,不能直接执行 A LEFT JOIN B ON B.aId = A.id LEFT JOIN C ON C.aId = A.id WHERE A.name = '666' AND B.state = 1 AND C.create_time > '2019-11-22 12:12:30'

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpwgjs.html