登录
首页 >  数据库 >  MySQL

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

时间:2024-11-14 18:12:49 342浏览 收藏

学习数据库要努力,但是不要急!今天的这篇文章《多字段查询导致索引失效?如何解决 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 字段的组合索引。这样,查询就可以直接从索引中获取所需的数据,无需回表,从而避免索引失效。

今天带大家了解了的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>