mysql允许在相同列上创建多个索引,无论是有意还是无意的,mysql需要单独维护重复主键索引,并且优化器在优化查询的时候也需要逐个进行考虑,这会影响性能
重复索引是指在相同列上按照相同的顺序创建的相同类型的索引,应该避免这样创建重复索引,发现以后也应立即删除
有时候会在不经意之间创建了重复索引,例如下面的代码
~~~
create table test (
id int not null primary key,
A int not null,
B int not null,
unique(id),
index(id)
)engine=Innodb;
~~~
用户可能想创建一个主键,先加上唯一限制,然后再加上索引以供查询使用.事实上,mysql的唯一限制和主键限制都通过索引实现的.
因此,上面的写法实际上在相同的列上创建了三个重复的索引.通常并没有这样做,除非是在同一列上创建不同类型的索引来满足不同的查询需求
如果索引类型不同,并不算是重复索引.例如经常有很好的理由创建key(col)和fulltext key(col)两种索引
表中的索引越多插入的速度越慢,一般来说,增加新索引将会导致insert update delete操作变慢,特别是当新增索引后导致达到内存瓶颈的时候
解决冗余索引和重复索引很简单,删除这些索引就可以,但首先要做的是找出这样的索引,可以通过写一些复杂的访问INFORMATION_SCHEMA表的查询来找,也可以使用pt-duplicate-key-checker,该工具通过分析表结构来找出冗余和重复的索引
在决定哪些索引可以被删除的时候要非常小心,innodb的示例中,因为二级索引的叶子节点包含了主键值,所以在列A上的索引相当于 (A,ID)上的索引.如果有像 where A = 5 order by ID这样的查询,这个索引会很有作用,如果把索引扩展为(A,B),则实际上会变为(A,B,ID),那么上面查询的order by 子句就无法使用索引排序,只能用文件排序了,所以建议用Percona工具中的pt-upgrade工具来仔细检查计划中的索引变更
- 书列表
- laravel框架关键技术
- 第一章 组件化开发与composer使用
- 简介
- composer
- 添加路由组件
- 添加控制器模块
- 添加模型组件
- 添加视图组件
- 第三章 laravel框架中常用的php语法
- 匿名函数
- 文件包含
- 魔术方法
- 魔术常量
- 反射
- 后期静态绑定
- traits
- 第四章 laravel框架中使用的HTTP协议基础
- HTTP协议
- 数据库
- 数据迁移
- 第六章 laravel框架中的设计模式
- IOC模式
- php核心技术与最佳实践
- 第一章面向对象核心
- 反射
- 简单ORM
- 异常和错误
- 接口
- 第二章,面向对象设计
- 设计原则
- 单一职责
- 接口隔离
- 开放封闭
- 替换原则
- 依赖倒置
- linux是怎么写的呢?
- 第三章 正则表达
- 认识正则
- 第四章 php网络技术应用
- HTTP协议详解
- php和http相关函数
- 垃圾信息防御措施
- 现代操作系统
- 引论
- sql必知必会
- 限制结果
- 按位置排序
- where求职顺序
- IN操作符
- like
- 函数
- group by
- 组合查询
- 插入检索出的数据
- 视图
- 高性能mysql
- 第一章节 mysql架构与历史
- mysql架构逻辑图
- 连接与管理
- 优化与运行
- 读写锁
- 锁粒度
- 表锁(table lock)
- 行级锁(row lock)
- ACID
- 隔离级别
- 死锁
- 隐式和显式锁定
- 多版本并发控制
- Innodb概览
- 第四章节 Schema与数据类型优化
- 选择优化的数据类型
- 日期和时间类型
- 标识列
- 特殊类型数据
- 表设计中的缺陷
- 范式
- 计数器表
- 第五章 创建高性能索引
- 索引基础
- 索引类型
- 索引的优点
- 高性能索引策略
- 选择合适的索引列顺序
- 聚簇索引
- 顺序的主键什么时候会造成更坏的后果
- 覆盖索引
- 使用索引扫描来做排序
- 压缩索引
- 冗余和重复索引
- 索引和锁
- 支持多种过滤条件
- 什么是范围条件
- 优化排序
- 维护索引和表
- 表损坏
- 减少索引和数据的碎片
- 第六章 查询性能优化
- 扫描的行数和访问类型
- 重构查询方式
- 查询执行的基础
- 重构-改善既有代码设计
- 第一章-重构
- 什么是重构
- 第一个案列
- 重构第一步
- 王垠博客
- 多态取代价格相关逻辑