我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql left join快速转inner join的详细过程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql left join快速转inner join的详细过程

这篇文章主要讲解了“mysql left join快速转inner join的详细过程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql left join快速转inner join的详细过程”吧!

在日常优化过程中,发现一个怪事情,同一个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.

感谢各位的阅读,以上就是“mysql left join快速转inner join的详细过程”的内容了,经过本文的学习后,相信大家对mysql left join快速转inner join的详细过程这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql left join快速转inner join的详细过程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql left join快速转inner join的详细过程

这篇文章主要讲解了“mysql left join快速转inner join的详细过程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql left join快速转inner join的
2023-06-20

mysql left join快速转inner join的过程

在日常优化过程中,发现一个怪事情,同一个SQL出现两个完全不一样执行计划,left join 连驱动表都可以变成不一样。对于left join,如果where条件里有被关联表过滤,left join有可能被转成inner join ,本案例
2022-05-15

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

开心一刻  我:嗨,老板娘,有冰红茶没  老板娘:有  我:多少钱一瓶  老板娘:3块  我:给我来一瓶,给,3块  老板娘:来,你的冰红茶  我:玩呐,我要冰红茶,你给我个瓶盖干哈?  老板娘:这是再来一瓶,我家卖完了,你去隔壁家换一下问题背景  对于 My
神奇的 SQL 之 联表细节 → MySQL JOIN 的执行过程(一)
2020-03-26

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

开心一刻  一头母牛在吃草,突然一头公牛从远处狂奔而来说:“快跑啊!!楼主来了!”  母牛说:“楼主来了关我屁事啊?”  公牛急忙说:“楼主吹牛逼呀!”  母牛大惊,拔腿就跑,边跑边问:“你是公牛你怕什么啊?”  公牛无奈道:“现在的楼主不仅吹牛逼,还扯蛋!”
神奇的 SQL 之 联表细节 → MySQL JOIN 的执行过程(二)
2021-08-08

docker swarm快速部署redis分布式集群的详细过程

这篇文章主要介绍了docker swarm快速部署redis分布式集群,只需要通过docker-compose.yml文件和一个启动命令就完成redis分布式部署的方式,让其分别部署在不同机器上,并实现集群搭建,需要的朋友可以参考下
2022-11-13

编程热搜

目录