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

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

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

在使用 mysql select 查询时,查询字段可能会影响索引的使用。最近,有位开发者遇到了一个问题:他的 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 字段的组合索引。这样,查询就可以直接从索引中获取所需的数据,无需回表,从而避免索引失效。

以上就是多字段查询导致索引失效?如何解决 MySQL 查询中的索引失效问题?的详细内容,更多请关注其它相关文章!