数据库索引

1、MySQL官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构。

可以得到索引的本质:索引是数据结构。

你可以简单理解为排好序的快速查找数据结构

2、面临问题

索引的目的在于提高查询效率,可以类比字典, 

如果要查“mysql”这个单词,我们肯定需要定位到m字母,然后从下往下找到y字母,再找到剩下的sql。 

如果没有索引,那么你可能需要a----z

3、细节

在数据之外, 数据库系统还维护着满足特定查找算法的数据结构 ,这些数据结构以某种方式引用(指向)数据, 这样就可以在这些数据结构上实现高级查找算法。这种数据结构,就是索引。

一般来说索引本身也很大,不可能全部存储在内存中,因此索引往往以索引文件的形式存储的磁盘上

优势:检索和排序

劣势:降低表的更新速率、索引表占用空间

4、mysql索引结构

BTree索引(每个磁盘快中含有数据、向下的指针、键值-表中的主键)

【初始化介绍】  

一颗b树,浅蓝色的块我们称之为一个磁盘块,可以看到每个磁盘块包含几个数据项(深蓝色所示)、指向深蓝色数据的指针和指针(黄色所示), 

如磁盘块1包含数据项17和35、指向这两个数据的指针和指针P1、P2、P3, 

P1表示小于17的磁盘块,P2表示在17和35之间的磁盘块,P3表示大于35的磁盘块。  

【查找过程】 

如果要查找数据项29,那么首先会把磁盘块1由磁盘加载到内存,此时发生一次IO,在内存中用二分查找确定29在17和35之间,锁定磁盘块1的P2指针,内存时间因为非常短(相比磁盘的IO)可以忽略不计,通过磁盘块1的P2指针的磁盘地址把磁盘块3由磁盘加载到内存,发生第二次IO,29在26和30之间,锁定磁盘块3的P2指针,通过指针加载磁盘块8到内存,发生第三次IO,同时内存中做二分查找找到29,结束查询,总计三次IO。 

B+Tree索引(没有存储实际的数据,只有走到叶子结点才能找到数据,所以能存储向下的指针更多了,相同多的数据,B+树层数更低,IO次数更少的情况下,更容易检索到数据)

思考:为什么说B+树比B-树更适合实际应用中操作系统的文件索引和数据库索引?  

1) B+树的磁盘读写代价更低  

  B+树的内部结点并没有指向关键字具体信息的指针。因此其内部结点相对B 树更小。如果把所有同一内部结点的关键字存放在同一盘块中,那么盘块所能容纳的关键字数量也越多。一次性读入内存中的需要查找的关键字也就越多。相对来说IO读写次数也就降低了。  

2) B+树的查询效率更加稳定  

  由于非终结点并不是最终指向文件内容的结点,而只是叶子结点中关键字的索引。所以任何关键字的查找必须走一条从根结点到叶子结点的路。所有关键字查询的路径长度相同,导致每一个数据的查询效率相当。 

5、聚簇索引和非聚簇索引

左侧的索引就是聚簇索引,因为数据行在磁盘的排列和索引排序保持一致。 

聚簇索引一般情况下就是该表的主键,按照聚簇索引排列顺序,查询显示一定范围数据的时候,由于数据都是紧密相连,数据库不不用从多个数据块中提取数据,所以节省了大量的io操作。

当创建表时没有显示定义主键时.

1 首先判断表中是否有非空的整形唯一索引,如果有,则该列为主键(这时候可以使用  select _rowid from table 查询到主键列).

2 如果没有符合条件的则会自动创建一个6字节的主键(该主键是查不到的).

注意:

聚簇索引主键的插入速度要比非聚簇索引主键的插入速度慢很多。相比之下,聚簇索引适合排序,非聚簇索引(也叫二级索引)不适合用在排序的场合。
因为聚簇索引本身已经是按照物理顺序放置的,排序很快。非聚簇索引则没有按序存放,需要额外消耗资源来排序。
当你需要取出一定范围内的数据时,用聚簇索引也比用非聚簇索引好。
另外,二级索引需要两次索引查找,而不是一次才能取到数据,因为存储引擎第一次需要通过二级索引找到索引的叶子节点,从而找到数据的主键,然后在聚簇索引中用主键再次查找索引,再找到数据。

6、索引分类

单值索引

即一个索引只包含单个列,一个表可以有多个单列索引

唯一索引

索引列的值必须唯一,但允许有空值

主键索引

设定为主键后数据库会自动建立索引,innodb为聚簇索引

复合索引

即一个索引包含多个列

7、索引SQL

创建:CREATE  [UNIQUE ]  INDEX [indexName] ON table_name(column)) 

删除:DROP INDEX [indexName] ON mytable; 

查看:SHOW INDEX FROM table_name

8、建索引情况

说明:mysql只会选择最好的一个索引使用,就算给所有字段建立了单值索引,mysql只会使用一个。所以最好情况是建立一个组合索引

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值