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 的全量匹配更快,所以更高效。

相关推荐
IT摆渡者7 小时前
MySQL性能巡检脚本分析报告
数据库·mysql
Lyyaoo.8 小时前
Redis基础
数据库·redis·缓存
杨云龙UP8 小时前
ODA登录ODA Web管理界面时提示Password Expired的处理方法_20260423
linux·运维·服务器·数据库·oracle
解救女汉子8 小时前
SQL触发器如何获取触发源应用名_利用APP_NAME函数追踪
jvm·数据库·python
weixin_5206498710 小时前
数据库函数
数据库
Bert.Cai11 小时前
MySQL LPAD()函数详解
数据库·mysql
OnlyEasyCode12 小时前
Navicat 任务自动备份指定数据库
数据库
if else12 小时前
Redis 哨兵集群部署方案
数据库·redis
yejqvow1212 小时前
Pandas 高效实现组内跨行时间戳匹配与布尔标记
jvm·数据库·python