码迷,mamicode.com
首页 > 数据库 > 详细

Mysql 索引问题集锦

时间:2018-10-01 00:08:37      阅读:206      评论:0      收藏:0      [点我收藏+]

标签:har   取出   版本   alter   rem   table   引擎   like   结构   

一、Mysql 中的索引
  • 索引:顾名思义用来检索、查找数据的key (字段)

  • 几种Mysql 中的常见索引分类:普通索引(联合索引)、唯一索引、主键索引、全文索引

  • 优点:使得查询数据变快

  • 缺点:更新数据时,也需要更新索引。所以更新速度变慢,占据磁盘空间
    注意:myisam中可以延迟更新索引

?

1.1.0 Myisam 下的非聚集索引

?
关于B+Tree 内容
Myisam 和 innodb 内容

  • myisam 为mysql 5.5 版本前的默认数据库引擎:
    myisam 使用B+Tree 结构存储数据。只有(只支持)主键索引、表锁,不支持外键,不支持事务,B+Tree 所有的非叶子节点都只存储 key
    myisam 在叶子节点 data 域存储的是数据的地址,不是数据,当myisam引擎进行查找时,先根据索引在索引表中找到位置,去对应的data域拿到数据所在地址
    然后去该地址提取出数据

?

1.1.1 innodb 下的聚集索引

  • innodb 为mysql 5.5 版本后的默认数据库引擎.
    ?
    innodb 也使用 B+Tree 结构存储数据,与myisam不同的有:支持外键、行锁、事务,B+Tree 的所有非叶子节点一样只存储 key
    ?
    innodb 在叶子节点 data 域存储的是数据,叶子节点数据类型[key, data], 当 innodb引擎进行查找时,根据索引找到 data 位置,直接将data 中的数据取出
    ?
    innodb 辅助索引(非主键索引外)进行查找时,根据辅助索引查找到 主键索引,再拿着主键索引到主键索引表中查找到 data 取出data。注意辅助索引并不存数据,

?

二、什么时候使用索引

?

  1. 经常使用在 where、group by 、order by 的后面查询的字段,可设置索引

  2. 减少使用子查询

  3. 多使用limit 这样数据量被限制较小,能提高查询速度

  4. 适度增加冗余字段,减少跨表查询,常用数据和不常用数据分表one2one保存

  5. 尽量不使用 * 查询数据,需要什么字段就查什么字段

  6. 别再数据库里面使用函数计算

  7. 尽量根据索引来检索数据

  8. 核心业务中别使用 like 语句模糊查询

  9. 将区分度字段写在where前面

?

三、添加索引

  1. 创建表时添加索引:
    create table tb_name(
    --> id int not null auto_increment primary key,
    --> name char(32) not null,
    --> identify_num bigint not null,
    --> unique key(identify_num),
    --> index name_index (name(32))
    --> );

  2. 更新表结构时添加:alter table tb_name add
    alter table tb_name add index name_index(name(32));
    ?
    create unique index identify_index on tb_name(identify_num)

?

四、索引失效

?

  1. like会导致索引失效
    ?
    like "%name" //失效的
    ?
    like "name%" //不失效

  2. 字段使用函数来修饰
    ?
    例:select * from u1 where md5(name) = ‘j‘

3、 联合索引中字段,将区分度较大的字段放大前面

Mysql 索引问题集锦

标签:har   取出   版本   alter   rem   table   引擎   like   结构   

原文地址:https://www.cnblogs.com/shiqi17/p/9733741.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!