多字段查询导致索引失效?如何解决 MySQL 查询中的索引失效问题?

多字段查询导致索引失效?如何解决 MySQL 查询中的索引失效问题?

多字段查询会导致索引失效?

在使用 mysqlselect 查询时,查询字段可能会影响索引的使用。最近,有位开发者遇到了一个问题:他的 sql 查询在只有几百条数据时可以使用索引,但是导入几万条数据后就无法使用了。

查询代码如下:

SELECT   dl.`user_type` AS userType,   dl.`user_name` AS userName,   dl.`phone` AS userPhone,   pc.`name` AS courtName,   dl.`build_unit` AS buildName,   dl.`dev_name` AS deviceName,   dl.`dev_no` AS deviceNo,   dl.`create_time` AS openTime,   dl.`status` FROM   dev_device_log dl   LEFT JOIN base_project_court pc     ON dl.`court_id` = pc.`id` ORDER BY dl.`id` DESC LIMIT 0, 100;

令人不解的是,当注释掉 pc.name 字段时,查询就可以使用索引了。

经过分析,问题出在索引覆盖之上。因为主键索引字段是 varchar(32),使用 utf8mb4 字符集,每个字符占用 4 字节。因此,主键索引的长度为 130 字节,mysql 优化器认为直接全表查询比逐行检索更有效率,于是放弃了索引。

为了解决这个问题,可以在 base_project_court 表上创建包含 id 和 name 字段的组合索引。这样,查询就可以直接从索引中获取所需的数据,无需回表,从而避免索引失效。

© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享