索引可以让服务器快速定位到表的指定位置.但是这并不是索引的唯一作用,到目前为止可以看到,根据创建索引的数据结构不同,索引也有一些其他的附加作用
最常见的B-Tree索引,按照顺序存储数据,所以mysql可以用来做order by和group by操作,因为数据是有序的,所以B-Tree也就将相关的列值都存储在一起.最后因为索引中存储了实际的列值,所以某些查询只使用索引就能够完成全部查询.据此特性,总结下来索引有如下三个优点
1. 索引大大减少了服务器需要扫描的数据量
2. 索引可以帮助服务器避免排序和临时表
3. 索引可以将随机I/O变为顺序I/O
"索引"这个主题建议阅读
![](https://box.kancloud.cn/c089bd8306f95a00c4403654d8aedda3_667x44.png)
这书详细介绍了如何计算索引的成本和作用,如何评估查询速度,如何分析索引维护的代价和其带来的好处等
书中介绍了如何评价一个索引是否适合某个查询的"三星系统",
**索引将相关的记录放到一起则获得一星.
如果索引中的数据顺序和查找中的顺序一致则获得二星.
如果索引中的列包含了查询中的需要的全部列则获得"三星"**
----
索引是最好的解决方案吗?
索引并不总是最好的工具.总的来说,只有当索引帮助存储引擎快速查找到记录带来的好处大于其带来的额外工作时,索引才是有效的,对于非常小的表,大部分情况下简单的全表扫描更高效.
对于中大型的表,索引就非常有效,
但对于特大型的表,建立和使用索引的代价将随之增长.这种情况下,则需要一种技术可以直接区分查询需要的一组数据,而不是一条记录一条记录的匹配,例如可以使用分区技术
如果表的数量特别多,可以建立一个元数据信息表,用来查询需要用到的某些特性,例如执行哪些需要聚合多个应用分布在多个表的数据的查询,则需要记录"那个用户的信息存储在那个表中"的元数据,这样在查询时就可以直接忽略那些不包含指定用户信息的表
对于大型系统,这是一个常用的技巧,事实上,Infobright就是使用类似的实现.对于TB级的数据,定位单条记录的意义不大,所以经常会使用块级别元数据技术来替代索引
- 书列表
- 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与数据类型优化
- 选择优化的数据类型
- 日期和时间类型
- 标识列
- 特殊类型数据
- 表设计中的缺陷
- 范式
- 计数器表
- 第五章 创建高性能索引
- 索引基础
- 索引类型
- 索引的优点
- 高性能索引策略
- 选择合适的索引列顺序
- 聚簇索引
- 顺序的主键什么时候会造成更坏的后果
- 覆盖索引
- 使用索引扫描来做排序
- 压缩索引
- 冗余和重复索引
- 索引和锁
- 支持多种过滤条件
- 什么是范围条件
- 优化排序
- 维护索引和表
- 表损坏
- 减少索引和数据的碎片
- 第六章 查询性能优化
- 扫描的行数和访问类型
- 重构查询方式
- 查询执行的基础
- 重构-改善既有代码设计
- 第一章-重构
- 什么是重构
- 第一个案列
- 重构第一步
- 王垠博客
- 多态取代价格相关逻辑