古柏树下
2019-12-09 13:04
采纳率: 72.7%
浏览 733

mysql为什么这样的sql执行时不走索引

表结构为

CREATE TABLE `person` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) DEFAULT NULL,
  `address` varchar(255) DEFAULT NULL,
  `first_name` varchar(255) DEFAULT NULL,
  `tel` varchar(255) DEFAULT NULL,
  `job` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `name-address` (`name`,`address`,`first_name`)
) ENGINE=InnoDB AUTO_INCREMENT=16804 DEFAULT CHARSET=utf8;

现有执行计划不走索引

EXPLAIN SELECT * FROM person force index(`name-address`) WHERE `name` = 2 AND `address` LIKE "%222" and first_name LIKE "%222";

EXPLAIN SELECT * FROM person force index(`name-address`) WHERE `name` = 1 AND address = 1

执行计划为

图片说明

图片说明

最终解决结果
图片说明

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • 一棵小白杨。 2019-12-09 14:20
    已采纳

    第一个不会走,第二个走,它与你用没用强制索引没有关系

    点赞 打赏 评论
  • 空白如空 2019-12-09 13:36

    LIKE "%xxx"这种情况是不走索引的
    https://blog.csdn.net/shadow_zed/article/details/89117125

    点赞 打赏 评论
  • 可以简单点 2019-12-09 13:51

    mysql最左匹配原则,左边的值不确定,不走索引,你的模糊查询%是一个不确定的值,所以不走索引

    点赞 打赏 评论

相关推荐 更多相似问题