mysql中left join 不一定比 in效率高案例

一 案例

1.1 说明

常规来说,left join语法 要比 写 in 效率高,查询快,但是万事有特殊情况,如下sql:

DESC

SELECT a.business_depart,b.user_id,c.name FROM bocai_ip_list AS a ,bocai_department_admin AS b, bocai_ip_list AS c WHERE

b.department_abbr=a.business_depart AND a.id='1057279' AND c.id=b.user_id

DESC

SELECT id,NAME FROM bocai_ip_list WHERE id IN (

SELECT b.user_id FROM bocai_ip_list AS a ,bocai_department_admin AS b WHERE

b.department_abbr=a.business_depart AND a.id='1057279'

)

using where;using index 为何第一个执行是这个,而第二个是using where;using index;LooseScan第二个比第一个高效呢?

1.2 分析说明

第二条用 IN 子查询触发了**MySQL 的 LooseScan 索引跳跃优化,这条 SQL 因为结果集小 + 索引完美,IN 触发了 LooseScan(索引跳跃扫描),**反而比多表 JOIN 更快。比第一条三表 JOIN 的全量匹配更快,所以更高效。

相关推荐
烁3478 小时前
Oracle学习
数据库·学习·oracle
Bert.Cai8 小时前
Oracle LENGTH函数详解
数据库·oracle
云和数据.ChenGuang8 小时前
大模型厂商常用的数据库有哪些?
数据库·人工智能·pytorch·深度学习·numpy
不吃土豆的马铃薯8 小时前
高并发服务器数据库连接池设计详解
服务器·网络·数据库·c++·mysql
Nontee8 小时前
新手数据库进阶:大白话图解MySQL的“官方档案”——Binlog
数据库·mysql
倒流时光三十年8 小时前
PostgreSQL VALUES 列表详解
数据库·postgresql
Nightwish58 小时前
Oracle 数据库巡检检查清单
数据库·oracle·ffmpeg
吴声子夜歌8 小时前
SQL经典实例——插入、更新和删除
数据库·sql
基德爆肝c语言8 小时前
MySQL:数据库基础
数据库·mysql
倒流时光三十年8 小时前
PostgreSQL GREATEST 条件表达式函数详解
服务器·数据库·postgresql