您现在的位置是:亿华云 > 域名
一个不留神,索引就创建重复了
亿华云2025-10-03 20:32:31【域名】0人已围观
简介相信没有人会故意创建重复的冗余的索引,很多重复和冗余的索引都是在不经意间创建的,今天松哥来和大家捋一捋这个问题。因为我们日常在使用 MySQL 的过程中,基本上都是使用 InnoDB 引擎,所以接下来
相信没有人会故意创建重复的留神冗余的索引,很多重复和冗余的索引索引都是在不经意间创建的,今天松哥来和大家捋一捋这个问题。创建
因为我们日常在使用 MySQL 的重复过程中,基本上都是留神使用 InnoDB 引擎,所以接下来的索引讨论主要是基于 InnoDB 引擎的 B+Tree 索引来讨论,其他的创建哈希索引全文索引等不在讨论范围种。
在前面的重复文章中,松哥通过好几篇文章和大家分享了联合索引,留神包括它涉及到的索引覆盖索引、前缀匹配等等,创建联合索引好用,重复但是留神对联合索引理解不到位的话,可能会创建出如下的索引重复索引:
CREATE TABLE `user2` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`username` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`address` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`password` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`email` varchar(16) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `user_index1` (`username`,`address`),
KEY `user_index2` (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;可以看到,这里创建了两个索引:
user_index1:这个索引包含两个字段,创建username 在前 address 在后。user_index2:这个索引包含一个字段 username。亿华云(username,address) 索引既可以当成联合索引来用,也可以通过最左匹配原则当成单独的 (username) 索引来用。
所以,如果再为 username 字段单独创建一个索引就没有必要了,这反而会导致增删改的时候速度变慢。
不过怎么说呢,上面这个结论适用于 99% 的场景,可能会有一些特殊情况,例如想把 (username) 和某一个特别长的字段建立一个联合索引,此时如果单独使用 username 字段进行搜索的话,效率可能降低,此时视搜索的重要程度,看是否需要创建一个重复的索引。
2. 主键加入联合索引中来看看下面这个索引:
CREATE TABLE `user2` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`username` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`address` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`password` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`email` varchar(16) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `user_index` (`username`,`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;一个名为 user_index 的索引中包含了两个字段 username 和 id,其中 id 是主键。
在什么是 MySQL 的“回表”?一文中,松哥和大家聊了,索引按照物理存储方式可以分为聚簇索引和非聚簇索引。
我们日常所说的主键索引,站群服务器其实就是聚簇索引(Clustered Index);主键索引之外,其他的都称之为非主键索引,非主键索引也被称为二级索引(Secondary Index),或者叫作辅助索引。
对于主键索引和非主键索引,使用的数据结构都是 B+Tree,唯一的区别在于叶子结点中存储的内容不同:
主键索引的叶子结点存储的是一行完整的数据。非主键索引的叶子结点存储的则是主键值以及索引列的值。这是两者最大的区别。
既然主键已经存在于叶子结点中,那当然没有在联合索引中加入主键了。
好啦,几个小小的注意点,希望能给小伙伴们启发。
参考资料:《高性能 MySQL》
云南idc服务商很赞哦!(6167)
相关文章
- 4、参加域名拍卖会
- 前端框架大比拼:2022年的Vue与React谁更胜一筹?
- 代码简洁之道:统一返回格式
- 字节的前端监控 SDK 是怎样设计的
- 其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
- 实现数组扁平化的六种方式
- 使用 Vite 和 TypeScript 带你从零打造一个属于自己的 Vue3 组件库
- 组员老是忘记打卡,我开发了一款小工具,让全组三个月全勤!
- 顶级域名可以增加企业品牌的价值。随着经济的快速发展,域名已不再是企业在网络中的独立地位。顶级域名的服务范围、企业产品、综合形象体现等,对于企业单位来说,顶级域名的重要性不言而喻。
- 协同编辑中使用的 OT 算法是什么?