数据库 索引
来源:互联网 发布:centos安装cacti 编辑:程序博客网 时间:2024/05/02 02:33
多数数据库,使用 B 树(Balance Tree)的结构来保存索引。
B 树,
最上层节点:根节点
最下层节点:叶子节点
两者之间的节点:中间节点
B 树,显著特征:从根节点,到各个叶子节点的距离都是相等的。如此,检索任何值时,都经过相同数目的节点。
伴随主键的定义而创建的特别索引,被称为:丛生索引(Clustered Index)
一个表,只有一个丛生索引。
普通的索引,在叶子节点中保存的是指向实际表的指针。
而,丛生索引,在叶子节点中保存的就是实际数据。
丛生索引,
不需要为保存索引,而使用专用的硬盘空间,节约资源
不需要检查索引后,再访问实际的表,提高了效率
创建丛生索引时,需要对表中数据进行排序,因此,在执行数据插入、更新、删除等操作时,比普通索引慢。
复合索引
唯一性索引
使用 UNIQUE 关键字,来创建不可重复的索引,称为:唯一性索引。
对特定列创建唯一性索引,相当于对该列追加了唯一性制约。
创建唯一性索引的时候,如果对象列中,已经含有重复数据,则:创建失败,报错。
创建成功后,如果,插入重复数据,则:插入失败,报错。
指定多个列,来创建唯一性索引,只要,这些列的组合数据不重复,就可以创建成功。
EXPLAIN 命令的说明:P100 表格
如果,创建索引后,遍历的次数与创建索引之前,变化不大。
说明,创建索引时,选择的列名不合理,需要选择合适的列重建索引。这是分析索引优劣的方法。
追加了索引后,也不能保证在每次检索时都会使用列索引。
如果, SQL 检索语句编写不当,就无法使用索引。
1、LIKE 运算符,进行模糊检索时,只能在前方一致的检索时,才能使用索引。
以下写法,索引不会被使用。
2、使用 IS NOT NULL 、 <> 的场合,也不会使用索引。如下:
3、对列使用了运算或者函数的情况下,不会使用索引,如下:
4、复合索引的第一列,没有包含在 WHERE 条件语句中,如下:
实际开发过程中,需要积极使用 EXPLAIN 命令,来确认索引的使用情况,及时作相应修改。
0 0
- 数据库 索引&索引类型
- 数据库索引,联合索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库 索引
- 数据库索引
- 数据库索引
- 数据库索引
- 数据库 索引
- Codeforces 711c 简单dp
- 初学TensorFlow 存在报错问题记录——中文备注 python编码问题
- java Map转XML
- c++高级编程内容
- 全站即时通讯技术资料分类
- 数据库 索引
- 悼念512汶川大地震遇难同胞
- effective java观后感(2)-------创建和销毁对象
- 几种向量空间
- JAVA学习笔记之(常用类)
- 全局描述符表(GDT)——《x86汇编语言:从实模式到保护模式》
- Java集合——容器
- 创建windows开机自启动方法
- SAP以创新提升极限帆船赛