Mysql第五天 索引

聚簇与非聚簇

首先Mysql中索引是使用了B+Tree的结构,具体数据结构可以看这里

聚簇索引: 其叶子节点就是对应了物理上的行,并且其保证了叶子结点的顺序与物理位置一致。 这个特性决定了其不适合使用在随机字符串类似的字段上,因为有可能会造成大量的数据移动。 还决定了其能够很好的利用数据库预读以及页读的功能很快的查找范围内的数据。

非聚簇索引: 其叶子节点存储了列值及到行的指针。因此其顺序跟物理顺序无关,插入的效率要高很多,因为仅仅是移动节点的指针不会涉及数据移动。

下面的图比较形象:

覆盖索引: 当要提取的数据在叶子节点中就能够获取,而不用去查找数据块时就叫做覆盖索引。因为索引中的数据时顺序的,并且空间比较小,因此会带来比较高的性能。

使用取舍:

行为 聚簇索引 非聚簇索引
列常被group by 可以 可以
列经常被between等范围查询 效率高 效率低
频繁更新的列 效率低 效率高
列常被order by 可以 可以
获取大于20%的数据 不可 不可

此外,在插入非常频繁的场景下,聚簇索引因为插入的热点都是在最尾端,因此有可能会有性能问题,可以通过配置innodb_autoinc_lock_mode 来配置这种情况下的处理方式,表锁还是预读预置一些值给语句使用

索引命中规则:

  • 全值匹配
  • 匹配最左前缀, 即多列索引,从最左列开始匹配
  • 匹配列前缀,即 A*这样的匹配方式
  • 匹配范围值, between and是可以的
  • 精确左,范围右。 where firstName=’123’ and middlename like ‘abc%’
  • 覆盖索引
  • order by 子句会用到索引

哈希索引

哈希索引使用了哈希算法。其具有如下的特性:

  • 只存储hash值和行指针,不存储字段值,因此不能用来读取单一行。
  • 不能用于排序
  • 只支持等值查找
  • 一般不会用到,如果想手工使用可以用mysql自带的CRC32方法来进一步的缩小范围

总结一下:

  • 单行访问很慢,因为随机I/O很慢。 最好读取的快中能够包含尽可能多的需要的数据,使用索引可以创建位置引用以提升效率
  • 按顺序访问数据很快。 顺序I/O不需要寻到,不需要而外的排序操作
  • 索引覆盖很快
时间: 2024-08-03 08:19:37

Mysql第五天 索引的相关文章

Mysql建表与索引使用规范详解

本篇文章是对Mysql建表和索引使用规范进行了详细的分析介绍,需要的朋友参考下   一. MySQL建表,字段需设置为非空,需设置字段默认值. 二. MySQL建表,字段需NULL时,需设置字段默认值,默认值不为NULL. 三. MySQL建表,如果字段等价于外键,应在该字段加索引. 四. MySQL建表,不同表之间的相同属性值的字段,列类型,类型长度,是否非空,是否默认值,需保持一致,否则无法正确使用索引进行关联对比. 五. MySQL使用时,一条SQL语句只能使用一个表的一个索引.所有的字段

Mysql建表与索引使用规范详解_Mysql

一. MySQL建表,字段需设置为非空,需设置字段默认值.二. MySQL建表,字段需NULL时,需设置字段默认值,默认值不为NULL.三. MySQL建表,如果字段等价于外键,应在该字段加索引.四. MySQL建表,不同表之间的相同属性值的字段,列类型,类型长度,是否非空,是否默认值,需保持一致,否则无法正确使用索引进行关联对比.五. MySQL使用时,一条SQL语句只能使用一个表的一个索引.所有的字段类型都可以索引,多列索引的属性最多15个.六. 如果可以在多个索引中进行选择,MySQL通常

python-关于mysql中的位图索引和位片索引问题

问题描述 关于mysql中的位图索引和位片索引问题 老师给了一个作业要求利用其他语言例如Python或者C++来实现位图索引,但是一直教的就是mysql,没要办法建位图索引啊.不知道怎么办才好了,求大神指导... 解决方案 Mysql 索引 解决方案二: http://www.cnblogs.com/yuerdongni/p/4255395.html

高性能的MySQL(5)索引策略-索引案例分析

理解索引最好的办法是结合实例,接下来分析一个例子. 假设要设计一个在线约会网站,用户信息表有很多列,包括国家,地区,城市,性别,眼睛颜色等等.网站必须支持上面的各种组合来搜索用户,包括根据用户的最后在线时间,评分等进行排序的限制. 需要考虑是需要索引来排序还是先检索数据再排序,因为使用索引排序会严格限制索引和查询的设计.如果MySQL使用了某个索引的范围查询,也就无法再使用另一个索引或者是该索引的后续字段进行排序了.接下来一步步讨论: 1.支持多种过滤条件 country列的选择性通常不高,但是

高性能的MySQL(5)索引策略-覆盖索引与索引排序

一.覆盖索引 索引是一种查找数据的高效方式,但是MySQL也可以使用索引来直接获取列的数据,这样就不再需要读取数据行.如果索引的叶子节点中已经包含要查询的数据,那么还有什么必要回表查询呢? 如果一个索引包含或者说覆盖所有需要查询的字段的值,我们就称之为"覆盖索引". 覆盖索引的好处: 1.索引条目通常远小于数据行大小,所以如果只需要读取索引,就极大的减少数据访问量.这对MyISAM尤其正确,因为MyISAM能压缩索引以变得更小. 2.因为索引是按照顺序存储的,所以对于I/O密集型的范围

Solr DIH: 基于MySQL表数据建立索引

选择使用Solr,对数据库中数据进行索引,可以单独写程序将数据库中的数据导出并建立索引,这个过程可能对于数据处理的控制更灵活一些,但是却可能带来很大的工作量.选择使用Solr的DIH组件,可以很方便的对数据库表中数据进行索引,下面基于MySQL数据库实现建立索引. 首先,需要设计你的schema,最主要的工作是,将数据库表中字段映射为Lucene索引(Solr直接使用Lucene的索引格式和数据)的Field,从而将数据表中的一条记录映射为Lucene中的Document,然后进行索引.另外,在

mysql建立合适的索引的例子

在mysql数据库中,其实建索引也是一门学问,一个表中,索引并不是越多越好,而是适合你的业务才最重要.那么建立索引的时候,我们应该从以下几点去考量.   1. 索引字段越小越好,像varchar(10)肯定比text类型的效果要好. 2. 经常需要作为where.group by.order by等条件的时候,要为该字段建立索引. 3. 当要建立联合索引的时候,离散度较大的列放到前面.打个比方,如果要建立一个姓名(name)和年龄(age)的联合索引,肯定要把name放到前面(index(nam

MySQL源码:索引相关的数据结构(前篇)

1. MySQL如何描述某个数据表的索引 MySQL使用TABLE对象来描述一个数据表,那么数据表的索引是如何描述,索引的统计信息又是如何存储的呢? 例如我们有如下数据表: CREATE TABLE `users` ( `id` int(11) NOT NULL, `nick` varchar(32) DEFAULT NULL, `reg_date` datetime DEFAULT NULL, PRIMARY KEY (`id`), KEY `IND_NICK` (`nick`), KEY `

MySQL数据库中的索引问题

问题描述 MySQL数据库中的索引问题 用index加索引,再用show create table命令查看得到的是key不是index了,这原因是什么.这两者之间有什么区别没哦?附上代码: create table tbl01( id int(10) key key_id (id)); show create table tbl01; CREATE TABLE tbl01 (id int(10) DEFAULT NULL KEY key_id (id)) ENGINE=InnoDB DEFAUL