B-Tree索引可能会碎片化,这会降低查询效率.碎片化的索引可能会以很差或者无序的方式存储在磁盘上
根据设计B-Tree需要随机磁盘访问才能定位到叶子页,所以随机访问是不可避免的.然而,如果叶子页在物理分布上是顺序且紧密的,那么查询性能就会更好.否则,对于范围查询,索引覆盖扫描等操作来说,速度可能会降低很多倍,对于索引覆盖扫描这一点更加明显
表的数据存储也可能碎片化.然而,数据存储的碎片化比索引更加复杂.有三种类型的数据碎片
* 行碎片
这种碎片指的是数据被存储为多个地方的多个片段中.即使查询只从索引中访问一行记录,行碎片也会导致性能下降
* 行间碎片
行间碎片是值逻辑上顺序的页,或者行在磁盘上不是顺序存储的.行间碎片对诸如全表扫描和聚簇索引扫描之类的操作有很大的影响,因为这些操作原本能够从磁盘上顺序存储的数据中获益
* 剩余空间碎片
剩余空间碎片是指数据页中有大量的空余空间,这会导致服务器读取大量大需要的数据,从而造成浪费
对于myisam表,这三类碎片化都可能发生.但Innodb不会出现短小的行碎片,innodb会移动短小的行并重写到一个片段中
可以通过执行OPTIMIZE TABLE或者导出再导入的方式来重新整理数据,这对多数存储引擎都是有效的.对于一些存储引擎如myisam,可以通过排序算法重建索引的方式来消除水平.老版本的Innodb没有什么消除碎片化的方法.不过最新版本Innodb新增了"在线"添加和删除索引的功能,可以通过先删除,然后再重新创建索引的方式来消除索引的碎片化
对于那些不支持OPTIMIZE TABLE的存储引擎,可以通过一个不做任何操作的ALTER TABLE操作来重建表.只需要将表的存储引擎改为当前的引擎即可:
~~~
mysql> ALTER TABLE <table> ENGINE=<engine>;
~~~
对于开启了`expand_fast_index_creation` 参数的Percona Server,按这种方式重建表,则会同时消除表和索引的碎片化.但对于标准版本的mysql则只会消除表(实际上是聚簇索引)的碎片化.可用先删除所有索引,然后重建表,最后重新创建索引的方式模拟Percona Server的这个功能
- 书列表
- 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与数据类型优化
- 选择优化的数据类型
- 日期和时间类型
- 标识列
- 特殊类型数据
- 表设计中的缺陷
- 范式
- 计数器表
- 第五章 创建高性能索引
- 索引基础
- 索引类型
- 索引的优点
- 高性能索引策略
- 选择合适的索引列顺序
- 聚簇索引
- 顺序的主键什么时候会造成更坏的后果
- 覆盖索引
- 使用索引扫描来做排序
- 压缩索引
- 冗余和重复索引
- 索引和锁
- 支持多种过滤条件
- 什么是范围条件
- 优化排序
- 维护索引和表
- 表损坏
- 减少索引和数据的碎片
- 第六章 查询性能优化
- 扫描的行数和访问类型
- 重构查询方式
- 查询执行的基础
- 重构-改善既有代码设计
- 第一章-重构
- 什么是重构
- 第一个案列
- 重构第一步
- 王垠博客
- 多态取代价格相关逻辑