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的表,其字符编码不同。
知其然,更要知其所以然。
分析问题的思路,比结论本身更重要。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
雷鸟创新AWE斩获艾普兰创新奖 蝙蝠侠限定款国内首秀
雷鸟X3 Pro斩获AWE艾普兰创新大奖,开启全民AR生活新篇章 在上海新国际博览中心隆重揭幕的2026年中国家电及消费电子博览会(AWE)上,前沿AI科技与未来生活愿景激情碰撞。全球消费级AR领导品牌雷鸟创新,以其里程碑式的表现,定义了行业发展的新方向。 通过“顶尖硬件科技+顶级文化IP”的双轨战
AWE探展MOVA:31款创新产品集中亮相 重新定义智慧生活新体验
借力AWE2026“一展双区”,MOVA双区协同、震撼登场 备受瞩目的科技盛会——2026年中国家电及消费电子博览会(AWE),于3月12日至15日在上海盛大举办。本届AWE展会首次创新采用“一展双区”的展览模式,主会场位于上海新国际博览中心,分会场则设于上海东方枢纽国际商务合作区,两大展区高效联动
iPhone 18 Pro设计挤牙膏了 继续用前代模具
iPhone 18 Pro系列模具不变,屏幕形态将与iPhone 17 Pro保持一致 备受期待的屏下Face ID组件小型化设计与灵动岛区域缩窄方案,预计将被推迟至后续迭代机型中正式应用。 近期,关于iPhone 18 Pro系列的技术传闻持续引发行业关注,尤其在显示与解锁设计领域传言甚多。多方消
海韵 FOCUS v5系列电源3.16日首发,标配ATX 3.1规范
海韵FOCUS v5电源正式上市:140mm短机身设计,白金能效,专为紧凑高性能主机打造 对于追求极致空间利用的DIY玩家,尤其是ITX与小尺寸机箱用户,一款高效且尺寸紧凑的电源是组建高性能主机的关键。海韵旗下备受期待的FOCUS v5系列电源,现已在京东自营旗舰店正式发售。该系列主打标准的140m
2026必买A级纯电SUV 方程豹钛3闪充版上市15万起
作为A级纯电市场首款标配闪充的方盒子车型,方程豹钛3闪充版凭借三大越级实力,问鼎同级科技与潮流标杆 2026年3月13日,方程豹品牌正式推出钛3闪充版,新车提供620KM后驱闪充版与565KM四驱闪充版两个车型配置,官方指导价定在15 38万至16 98万元区间。同步,备受期待的钛7EV闪充版也启动
- 日榜
- 周榜
- 月榜
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程

