jdbc 中mysql查询语句id in_MySQL实战第83篇:优化器,MySQL中执行查询语句第4步!...

欢迎来到MySQL实战第83篇,修炼500篇,学习需要一步一的一个脚印。

35162fb7456b74f2a659f5c8f6a8be13.png

【背景介绍】

经过了分析器,MySQL就知道了查询任务是什么了?在开始执行之前,需要先经过优化器的处理。

在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多个表关联的时候,决定各个表的连接顺序(join)。

【案例分析】

68d7392310582b7cd0bc8ad3a2f3c42a.png

比如我们执行上面的两个语句,这个语句是执行两个表的join:

<1>既可以先从表fruits里面取出s_id=101的记录的s_id值,在根据s_id值关联到表suppliers.s_id,在判断suppliers.s_zip=30000;

<2>先从表suppliers里面取出s_zip=30000d的记录的s_id值,再根据s_id值关联到fruits再判断fruits里面的s_id的值是否等于101

2bd4a002b5911a0e12bbd205531453a2.png

这两种方案的从逻辑上来讲是一样的,但是执行的效率确不相同。而优化器的本领就是决定使用哪个方案

优化器阶段完成后,也就是说选择了执行的方案,下面就开始进入动手阶段(执行)了。

efeddc24155edab811a8198e22079c0c.png

求关注,让我们一起修炼吧!MySQL是我们的选择!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值