古柏树下 2019-12-09 13:04 采纳率: 100%
浏览 838
已采纳

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

执行计划为

图片说明

图片说明

最终解决结果
图片说明

  • 写回答

4条回答 默认 最新

  • 无双_ 2019-12-09 14:20
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?