游乐游手机版
首页/科技数码/文章详情

MySQL索引两类全表扫描隐患的排查与优化策略

时间:2026-03-05 13:55
在之前的文章中,举了一个强制类型转换导致死锁的例子,有朋友询问是不是类型转换都不能命中索引,花1分钟细说一下。 《两个小公举,调试MySQL死锁必备!》中,举了一个强制类型转换导致死锁的例子,有朋友

在上篇文章里,我们举了一个因强制类型转换导致死锁的例子。有朋友问到,是不是所有类型转换都不能命中索引呢?花一分钟详细说说。

在《两个小公举,调试MySQL死锁必备!》一文中,我们曾提到过一个因强制类型转换引发死锁的案例。有朋友因此追问,是否所有类型转换都会导致索引失效?接下来,我们就花一分钟,把这个问题讲清楚。

第一类:“列类型”与“where值类型”不符,不能命中索引,会导致全表扫描(full table scan)。

数据准备:

create table t1 (cell varchar(3) primary key)engine=innodb default charset=utf8;
insert into t1(cell) values (‘111’),(‘222’),(‘333’);

cell字段为varchar字符串类型,同时作为主键,即聚簇索引(clustered index)。我们往t1表中插入了3条测试数据。

测试语句:

explain select * from t1 where cell=111;
explain select * from t1 where cell=’111’;

第一条语句中,where条件的值类型是整数(与表定义中cell的类型不符);第二条语句,where条件的值类型是字符串(与cell类型一致)。

测试结果:

可以看到,当发生强制类型转换时,索引无法命中,查询需要扫描全表(共3条记录);而当类型一致时,索引命中,仅扫描一条记录。

第二类:相join的两个表的字符编码不同,不能命中索引,会导致笛卡尔积的循环计算(nested loop)。

数据准备:

create table t2 (cell varchar(3) primary key)engine=innodb default charset=latin1;
insert into t2(cell) values (‘111’),(‘222’),(‘333’),(‘444’),(‘555’),(‘666’);
create table t3 (cell varchar(3) primary key)engine=innodb default charset=utf8;
insert into t3(cell) values (‘111’),(‘222’),(‘333’),(‘444’),(‘555’),(‘666’);

t2与t1的字符集不同,我们插入了6条测试数据。t3与t1字符集相同,同样插入了6条测试数据。除此之外,t1、t2、t3三张表的表结构完全相同。

测试语句:

explain select * from t1,t2 where t1.cell=t2.cell;
explain select * from t1,t3 where t1.cell=t3.cell;

第一个join连接的是t1和t2(字符集不同),关联字段是cell;第二个join连接的是t1和t3(字符集相同),关联字段同样是cell。

测试结果:

由于t1和t2字符集不同,底层存储空间不同,当它们进行join时,执行计划显示需要先遍历t1的所有记录(3条),然后t1的每一条记录又要去遍历t2的所有记录(6条),实际上进行了笛卡尔积循环计算(nested loop),索引完全失效了。

而在t1与t3的join中,虽然也遍历了t1的所有记录(3条),但t1的每一条记录都可以利用t3的索引进行快速查找,即仅扫描一行记录,效率显著提升。

画外音:图片请放大查看。

总结

这里总结了两类容易被忽视、导致索引失效的情形:

表列类型,与where条件的值类型不一致;参与join的表,其字符编码不同。

知其然,更要知其所以然。

分析问题的思路,比结论本身更重要。

来源:https://www.51cto.com/article/836193.html
上一篇施罗德履新舍弗勒首席运营官,陈相滨接任中国区CEO 下一篇香港大学研发万能图像编辑器:一个AI模型搞定所有图片处理
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
宫本茂亲签3DS XL拍卖价破两万美元
科技数码 · 2026-05-29

宫本茂亲签3DS XL拍卖价破两万美元

今天来说一件挺有意思的事:2015年任天堂世界锦标赛冠军约翰·戈德堡,近日将他当年夺冠时赢得的宫本茂亲笔签名版3DS XL掌机放上了拍卖平台。截至2026年5月29日,这台签名掌机的竞拍价已突破两万美元,并且价格还在持续攀升。戈德堡在社交媒体上发布声明表示,经过相当长时间的慎重考虑,他决定将这台对自

七彩虹隐星P16 Pro游戏本新配置仅售7799元
科技数码 · 2026-05-29

七彩虹隐星P16 Pro游戏本新配置仅售7799元

七彩虹近期推出隐星P16Pro游戏本新配置,售价7799元。其搭载酷睿i9-13900HX处理器与RTX5060显卡,配备16英寸2 5K高刷电竞屏及高效散热系统。存储组合为16GB内存与1TB固态硬盘,支持后续扩展。该配置主打高性能性价比,适合预算有限但追求强劲性能的游戏玩家与轻度创作者。

苹果iPhone Hikawa握把支架448元重新上架
科技数码 · 2026-05-29

苹果iPhone Hikawa握把支架448元重新上架

苹果公司重新上架了与艺术家贝利·桧川及PopSockets合作设计的iPhone专用握把支架。该配件采用磁吸设计,兼具握持与支架功能,旨在通过人性化设计降低握持负担,并提供三种配色可选,售价448元。

苹果体育应用扩展至170市场 为2026世界杯引入对阵图
科技数码 · 2026-05-29

苹果体育应用扩展至170市场 为2026世界杯引入对阵图

苹果体育应用新增覆盖90多个国家和地区,全球可用市场总数超过170个。为迎接2026年世界杯,应用加入了完整的赛程对阵图和可视化阵型卡片,方便用户追踪赛事与战术。同时,应用支持实时活动功能,可将比分固定在锁屏或表盘,并新增一键跳转至新闻的入口。目前该应用仍仅限iPhone用户使用。

小米史上最强国产巅峰芯片玄戒O3 6月台积电3nm投产
科技数码 · 2026-05-29

小米史上最强国产巅峰芯片玄戒O3 6月台积电3nm投产

据博主爆料,小米下一代自研玄戒芯片计划于今年6月正式进入量产阶段,此次将采用台积电3nm工艺。初代玄戒O1累计出货量已突破100万颗,量产验证十分扎实。新一代芯片的产能将显著提升,这意味着供货问题基本得到解决。 根据现有曝光信息,这颗迭代芯片极有可能命名为玄戒O3,首发搭载机型预计为小米MIX Fo