登录
首页 >  数据库 >  MySQL

MySQL 联合索引

来源:SegmentFault

时间:2023-01-25 14:57:04 341浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《MySQL 联合索引》,聊聊MySQL、索引,我们一起来看看吧!

引言

用户表软删除,要保证手机号唯一且与已删除的用户不冲突,在数据库层面设置了

CREATE TABLE `test` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) CHARACTER SET utf8 NOT NULL,
  `delete_at` bigint,
  PRIMARY KEY (`id`),
  UNIQUE KEY `UK2lcfdkjf5bcn2bs7kfwyjhr91` (`username`,`delete_at`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

执行语句,索引创建成功:

image.png

去表中新建两条数据为

CREATE TABLE `test` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) CHARACTER SET utf8 NOT NULL,
  `delete_at` bigint DEFAULT 0 NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `UK2lcfdkjf5bcn2bs7kfwyjhr91` (`username`,`delete_at`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

最左匹配原则

为了提高查询效率,过去一直在

SELECT * FROM test WHERE username = 'admin';

EXPLAIN
分析以下这个语句,发现该语句的
Extra
Using index
,说明本次查询是走索引的,并且就是联合索引
UK2lcfdkjf5bcn2bs7kfwyjhr91

image.png

索引其实就是使用

B+
树进行排序,联合索引就是根据多个字段进行排序。

比如这里的

username
delete_at
的联合索引,先对
username
进行排序,
username
相同时,对
delete_at
进行排序,所以
username
绝对有序,
delete_at
相对有序。

所以根据

username
查询,完全可以使用已经绝对有序的联合索引,而
delete_at
理论上就不能使用该索引。

总结

EXPLAIN
工具在数据库学习与优化过程中很重要,推荐学习:MySQL 性能优化神器 Explain 使用分析 - segmentfault

到这里,我们也就讲完了《MySQL 联合索引》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于mysql的知识点!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表