Mysql索引分类

MackingJay

主键索引

主键是一种唯一性索引,但是它必须指定为PRIMARY KEY。

为什么Mysql主键设置为自增型ID

1.mysql 中的数据都是按顺序保存在 B+ 树上的,索引本身是有序的
2.mysql在底层是以数据页来存储数据的(计算机是分页读取和存储的,通常会读取页的整数倍,一般一页为4KB,mysql巧妙的利用了这个原理,将数据页面设置为磁盘页的整数倍,默认为16KB,可以通过innodb_page_size来设置),也就是说如果一个数据页存满了,mysql 就会去申请一个新的数据页来存储数据。如果主键是非自增 id,为了确保索引有序,mysql 就需要将每次插入的数据都放到合适的位置上。这样会造成页分裂和页合并出现,严重影响插入效率。

唯一索引

索引列的的所有值只能出现一次,即必须保持唯一,但可以为空。

普通索引

基本的索引类型,值可以为空,没有唯一性的限制。

索引覆盖

select的数据列只用从索引中就能够取得,不必读取数据行,换句话说查询列要被所建的索引覆盖
比如表emp有id name age,id为主键,name列建有索引。
select * from emp where name=?在name索引中拿到id后,还要去聚簇索引中获取整行数据,select id,name from emp where name=?则不用回表操作,查询的列已经被所建的索引覆盖

全文索引

全文索引的索引类型为FULLTEXT。全文索引可以在varchar,char,text类型的列创建

联合索引

多列值组成的索引,用于专门组合搜索。

最左前缀匹配原则

最左优先,以最左边的为起点任何连续的索引都能匹配上。同时遇到范围查询(>、<、between、like)就会停止匹配。

  1. 如果不是使用索引的最左列,则无法使用索引
  2. 不能跳过索引中的列,如select from tab where a= and c=,则只能用到索引的第一列a
  3. 如果查询中的莫个列有范围查询,则右边的列都无法使用索引,如:select * from tab where a= and b> and c=  则索引只能用到a,b列
索引下推

当使用索引条件下推优化时,如果存在某些被索引的列的判断条件时,MySQL服务器将这一部分判断条件传递给存储引擎,然后由存储引擎通过判断索引是否符合MySQL服务器传递的条件,只有当索引符合条件时才会将数据检索出来返回给MySQL服务器。换句话说,就是索引下推优化技术其实就是充分利用了索引中的数据,尽量在查询出整行数据之前过滤掉无效的数据。

阅读 160
4 声望
0 粉丝
0 条评论
4 声望
0 粉丝
宣传栏