【MySQL 数据宝典】【索引原理】- 003 用例子说明索引优化基础原则

本文详细介绍了在MySQL中如何准备数据、创建联合索引,以及遵循最左匹配原则进行查询优化。讨论了索引失效的各种场景,包括范围查询、计算、函数使用和like操作,并提供了使用覆盖索引的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、数据准备

1.1 创建数据库、表,插入数据

create database idx_optimize character set 'utf8';

CREATE TABLE users(
  id INT PRIMARY KEY AUTO_INCREMENT,
  user_name VARCHAR(20) NOT NULL COMMENT '姓名',
  user_age INT NOT NULL DEFAULT 0 COMMENT '年龄',
  user_level VARCHAR(20) NOT NULL COMMENT '用户等级',
  reg_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间'
);

INSERT INTO users(user_name,user_age,user_level,reg_time)
VALUES('tom',17,'A',NOW()),('jack',18,'B',NOW()),('lucy',18,'C',NOW());

1.2 创建联合索引

ALTER TABLE users ADD INDEX idx_nal (user_name,user_age,user_level) USING BTREE;

二、优化原则示例

2.1 最左匹配原则

如果创建的是联合索引,就要遵循该法则. 使用索引时,where后面的条件需要从索引的最左前列开始使用,并且不能跳过索引中的列使用。

2.1.1 场景说明

场景 1: 按照索引字段顺序使用,三个字段都使用了索引,没有问题。
EXPLAIN SELECT * FROM users WHERE user_name = 'tom' 
AND user_age = 17 AND user_level = 'A';

image.png

场景 2 : 直接跳过user_name使用索引字段,索引无效,未使用到索引
EXPLAIN SELECT * FROM users WHERE user_age = 17 AND user_level = 'A';

image.png

场景 3: 不按照创建联合索引的顺序,使用索引
EXPLAIN SELECT 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值