MySql索引

索引

数据结构

mysql的数据是存储在磁盘上的,满足对日常操作【CRUD】的高效稳定,可以通过提升硬件配置来解决。选用合适的数据结构也很关键,innodb采用的就是一种名为【B+树】的数据结构。

我们之前学习过的innodb数据是以【行】为单位,存在一个大小为16k【页】中,B+树的作用就是按照一个组织形式,将所有的【页】组织关联起来。

B-树

Balance(平衡),类似一种平衡二叉树。

B-树的特点:

  1. 所有的键值分步在整棵树中;

  2. 任何一个关键字出现且只出现在一个结点中

  3. 搜索有可能在非子结点结束

  4. 在关键字全集内做一次查找,性能逼近二分查找

B+树

是B-树的变体,是一种多路搜索树。

特点:

  1. 所有的关键字都存储在子结点

  2. 为所有的子结点增加了一个双向指针

选择使用B+树的原因:

  • 相同的空间,不存放【整行数据】就能存【更多的id】,B+树能使每个结点能检索的【范围更大、更精确、极大的减少了I/O操作,层高较低,通常3到4层就可以支持百万级的数据量】

  • Mysql是关系型数据库,B+树子结点增加了双向指针,加强了区间的方文星,可以在范围内查询。

查询相同的记录,使用【id列】比使用【非主键列】快几百倍!!!

  • 使用主键列查找数据时,可以利用B+树的特定,自上向下查询

  • 使用非主键列只能从子结点进行【全表扫描】,一个一个的比较。

索引的分类和创建

聚簇索引和非聚簇索引

【主键和数据】共存的索引被称之为【聚簇索引】。

【username和数据】建立的索引【非聚簇索引】。

聚簇索引只有在innodb引擎中才存在,再MyIsam中是不存在的。

Innodb使用的时聚簇索引,他会将主键组织到一颗B+树中,而行数据存储在叶子结点上,

如果使用的是where id=1这样的条件查询主键,按照B+树的检索算法来查找对应的叶子结点,获得行的数据。

如果对username列进行搜索,并且username列已经建立索引,需要两个步骤:

  • 第一步在非聚簇索引中检索username,到达其子结点获取对应的主键

  • 第二步使用主键在聚簇索引B+数中再执行一次B+树检索操作,最后达到叶子结点集合获取整行的数据。

MyIsam使用的是非聚簇索引。

普通索引

创建索引:

-- 给username整列添加索引
create index idx_user_name on user(user_name);
-- 给email可以截取前几个字符
create index idx_email on user(email(5));

创建索引本身是一个非常耗资源的操作。

创建索引之后,查询效率会显著提升。

删除索引:

drop index idx_user_name on user;

修改索引:

-- 通过修改的方式来添加索引
ALTER table user add index idx_email (email)
-- 在创建表的同时创建索引
CREATE table student (
    sid int,
    sname varchar(20),
    gender varchar(1),
    index idx_sid (sid)
);

唯一索引

对列的要求:索引列的值不能重复。

创建唯一索引:

-- 创建唯一索引
create unique index idx_email on user(email);
-- 也可以通过修改的方式添加唯一索引
ALTER table user add unique index idx_email (email)

唯一索引和主键的区别:

  • 唯一索引列允许空值,主键列不能为空

  • 主键列在创建时,已经默认为非空+唯一索引

  • 主键可以被其他表引用为外键,但是唯一索引不能用为外键

  • 一个表只能有一个主键,但是可以创建多个唯一索引

  • 主键更适合不容易更改的标识,如:身份证号,自增

唯一约束和唯一索引的区别:

  • 都可以实现数据的唯一,数据都可以为null

  • 创建唯一约束,会自动创建一个同名的唯一索引,该索引不能单独删除,删除约束时会自动删除索引。唯一约束是通过唯一索引来实现数据的唯一。

  • 创建一个唯一索引,这个索引就是一个独立的索引,是可以单独删除

  • 建议,如果想要让索引和约束单独存在,先建立唯一索引,再建立唯一约束。

使用索引的问题

哪些情况下适合建立索引

  • 频繁作为where条件语句查询的字段

  • 关联字段需要建立索引

  • 分组,排序字段可以建立索引

  • 统计字段可以建立索引

哪些情况不适合建立索引

  • 频繁更新的字段

  • where条件中用不到的字段

  • 表数据可以确定比较少

  • 数据重复且发布比较均匀的资源

  • 参与列计算

索引失效

  • 如果查询条件中有or,除非全部条件都有索引。

  • 复合索引不满足最左原则

  • like查询以“%”开头

  • 存在列计算

  • 如果mysql使用全表扫描比使用索引快:结果量很大。

  • 列存在类型转换

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值