mysql left join快速转inner join的过程

作者:福禄网络技术团队 时间:2024-01-26 19:08:17 

在日常优化过程中,发现一个怪事情,同一个SQL出现两个完全不一样执行计划,left join 连驱动表都可以变成不一样。

mysql left join快速转inner join的过程

mysql left join快速转inner join的过程

对于left join,如果where条件里有被关联表过滤,left join有可能被转成inner join ,本案例中shopInfo有ShopCategory = 'LOC'过滤条件; 保证shopInfo的记录非NULL,因此left join在优化过程中可以转为inner join。 那么O和S的JOIN顺序就是可以交换的。

验证结论:

创建表:


--班级表
CREATE TABLE T_CLASS(
 class_id int not null,
 class_name VARCHAR2(100)
);
添加索引
alter table T_CLASS add index inx_class_id(class_id);

--学生表
CREATE TABLE T_STUDENT(
 student_id int not null,
 class_id int not null,
 student_name VARCHAR(100),
 age int,
 sex int
)
添加索引
alter table T_STUDENT add index index_age(AGE);

--班级数据
insert into T_CLASS (CLASS_ID, CLASS_NAME)
values (1, '一班');

insert into T_CLASS (CLASS_ID, CLASS_NAME)
values (2, '二班');

insert into T_CLASS (CLASS_ID, CLASS_NAME)
values (3, '三班');

insert into T_CLASS (CLASS_ID, CLASS_NAME)
values (4, '四班');

insert into T_CLASS (CLASS_ID, CLASS_NAME)
values (5, '五班');

--学生数据
insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (1, 1, '李1', 3, '1');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (2, 1, '李2', 2, '1');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (3, 1, '李3', 3, '1');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (4, 2, '李4', 4, '1');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (5, 2, '李5', 3, '2');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (6, 2, '李6', 3, '1');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (7, 3, '李7', 6, '2');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (8, 3, '李8', 4, '2');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (9, 2, '李9', 2, '2');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (10, 2, '李10', 3, '1');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (11, 3, '李11', 3, '2');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (12, 2, '李12', 8, '2');

insert into T_STUDENT (STUDENT_ID, CLASS_ID, STUDENT_NAME, AGE, SEX)
values (13, 1, '李13', 6, '2');

案例1:B表有where条件且不为null

mysql left join快速转inner join的过程

案例2: A表和B表均有where条件且不为null

mysql left join快速转inner join的过程

案例3:A表和B表均有where条件且不为null,删除B表索引

mysql left join快速转inner join的过程

结论:

left join 只有被关联表有where条件,且其过滤条件优于关联表的情况下,mysql优化器才转成inner join.

来源:https://www.cnblogs.com/fulu/p/14914753.html

标签:mysql,left,join,inner,join
0
投稿

猜你喜欢

  • python 实现定时任务的四种方式

    2023-06-28 14:37:27
  • JavaScript实现图片无缝滚动效果

    2024-05-02 16:10:49
  • 基于Python 函数和方法的区别说明

    2023-10-03 02:04:01
  • 【MongoDB for Java】Java操作MongoDB数据库

    2023-07-14 01:10:43
  • Golang Mutex互斥锁深入理解

    2024-04-25 13:18:08
  • Python如何存储和读取ASCII码形式的byte数据

    2021-05-18 04:31:39
  • 番茄的js表单验证类

    2008-01-07 13:53:00
  • Python实现将数据写入netCDF4中的方法示例

    2023-12-30 15:51:18
  • 浅谈Pycharm最有必要改的几个默认设置项

    2021-10-13 05:33:38
  • 使用Python手工计算x的算数平方根,来自中国古人的数学智慧

    2021-12-07 01:29:53
  • Python实现的多叉树寻找最短路径算法示例

    2023-03-07 16:37:23
  • python登录pop3邮件服务器接收邮件的方法

    2021-09-21 18:05:15
  • python help函数实例用法

    2022-05-03 23:29:32
  • SQL中位数函数实例

    2024-01-25 17:21:55
  • 如何用python抓取B站数据

    2023-07-19 20:02:55
  • Python学习之yaml文件的读取详解

    2023-04-20 14:06:42
  • Python 编程操作连载之字符串,列表,字典和集合处理

    2021-08-16 11:27:54
  • JavaScript判断变量是否为undefined的两种写法区别

    2024-04-19 09:53:50
  • js 玩转正则表达式之语法高亮

    2023-06-24 05:35:42
  • python虚拟环境完美部署教程

    2021-09-10 17:54:02
  • asp之家 网络编程 m.aspxhome.com