索引的常见模型有哈希表、有序数组和搜索树。

哈希表:一种以 KV 存储数据的结构,只适合等值查询,不适合范围查询。

有序数组:只适用于静态存储引擎,涉及到插入的时候比较麻烦。可以参考 Java 中的 ArrayList。

搜索树:按照数据结构中的二叉树来存储数据,不过此时是 N 叉树(B+树)。广泛应用在存储引擎层中。

B+树比 B 树优势在于:

B+ 树非叶子节点存储的只是索引,可以存储的更多。B+树比 B 树更加矮胖,IO 次数更少。

B+ 树叶子节点前后管理,更加方便范围查询。同时结果都在叶子节点,查询效率稳定。

B+树中更有利于对数据扫描,可以避免 B 树的回溯扫描

索引的优点:

唯一索引可以保证每一行数据的唯一性 ;

提高查询速度 ;

加速表与表的连接 ;

显著的减少查询中分组和排序的时间;

通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。

索引的缺点:

创建跟维护都需要耗时 ;

创建索引时,需要对表加锁,在锁表的同时,可能会影响到其他的数据操作 ;

索引需要磁盘的空间进行存储,磁盘占用也很快;

当对表中的数据进行 CRUD 的时,也会触发索引的维护,而维护索引需要时间,可能会降低数据操作性能。

索引的设计原则:

索引不是越多越好。索引太多,维护索引需要时间跟空间;

频繁更新的数据,不宜建索引;

数据量小的表没必要建立索引。

重复率小的列建议生成索引。因为重复数据少,索引树查询更有效率,等价基数越大越好;

数据具有唯一性,建议生成唯一性索引。在数据库的层面,保证数据正确性 ;

频繁 group by、order by 的列建议生成索引。可以大幅提高分组和排序效率 ;

经常用于查询条件的字段建议生成索引。通过索引查询,速度更快。

索引失效的场景:

模糊搜索:左模糊或全模糊都会导致索引失效,比如'%a'和'%a%'。但是右模糊是可以利用索引的,比如'a%' 。

隐式类型转换:比如 select * from t where name = xxx , name 是字符串类型,但是没有加引号,所以是由 MySQL 隐式转换的,所以会让索引失效 3、当语句中带有 or的时候:比如 select * from t where name=‘sw’ or age=14

不符合联合索引的最左前缀匹配:(A,B,C)的联合索引,你只 where 了 C 或 B 或只有 B,C

索引的基本概念

主键索引:主键索引的叶子节点存的是整行数据信息。在 InnoDB 里,主键索引也被称为聚簇索引(clustered index)。主键自增是无法保证完全自增的哦,遇到唯一键冲突、事务回滚等都可能导致不连续。

唯一索引:以唯一列生成的索引,该列不允许有重复值,但允许有空值(NULL)

普通索引跟唯一索引查询性能:InnoDB 的数据是按数据页为单位来读写的,默认每页 16KB,因此这两种索引查询数据性能差别微乎其微。

change buffer:普通索引用在更新过程的加速,更新的字段如果在缓存中,如果是普通索引则直接更新即可。如果是唯一索引需要将所有数据读入内存来确保不违背唯一性,所以尽量用普通索引。

非主键索引:非主键索引的叶子节点内容是主键的值。在 InnoDB 里,非主键索引也被称为二级索引(secondary index)

回表:先通过数据库索引扫描出数据所在的行,再通过行主键id取出索引中未提供的数据,即基于非主键索引的查询需要多扫描一棵索引树。

覆盖索引:如果一个索引包含(或者说覆盖)所有需要查询的字段的值,我们就称之为覆盖索引。

联合索引:相对单列索引,组合索引是用多个列组合构建的索引,一次性最多联合 16 个。

最左前缀原则:对多个字段同时建立的组合索引(有顺序,ABC,ACB 是完全不同的两种联合索引) 以联合索引(a,b,c)为例,建立这样的索引相当于建立了索引a、ab、abc 三个索引。另外组合索引实际还是一个索引,并非真的创建了多个索引,只是产生的效果等价于产生多个索引。

索引下推:MySQL 5.6 引入了索引下推优化,可以在索引遍历过程中,对索引中包含的字段先做判断,过滤掉不符合条件的记录,减少回表字数。

索引维护:B+树为了维护索引有序性涉及到页分裂跟页合并。增删数据时需考虑页空间利用率。

自增主键:一般会建立与业务无关的自增主键,不会触发叶子节点分裂。

延迟关联:通过使用覆盖索引查询返回需要的主键,再根据主键关联原表获得需要的数据。

InnoDB 存储: .frm 文件是一份定义文件,也就是定义数据库表是一张怎么样的表。.ibd 文件则是该表的索引,数据存储文件,既该表的所有索引树,所有行记录数据都存储在该文件中。

MyISAM 存储: .frm 文件是一份定义文件,也就是定义数据库表是一张怎么样的表。 .MYD 文件是 MyISAM 存储引擎表的所有行数据的文件。* .MYI 文件存放的是 MyISAM 存储引擎表的索引相关数据的文件。MyISAM 引擎下,表数据和表索引数据是分开存储的。

MyISAM 查询:在 MyISAM 下,主键索引和辅助键索引都属于非聚簇索引。查询不管是走主键索引,还是非主键索引,在叶子结点得到的都是目的数据的地址,还需要通过该地址,才能在数据文件中找到目的数据。

PS:InnoDB 支持聚簇索引,MyISAM 不支持聚簇索引。

mysql索引ab和ba_Mysql中的索引相关推荐

  1. mysql支持非关系_说下oracle、mysql、非关系型数据库中的索引结构?

    谢邀~~树懒君悉心整理了一篇索引结构方面的内容,跟各位知友分享分享~ Oracle 索引的数据结构:B-TreeOracle 数据库使用 B-trees 存储索引,来加速数据访问.若没有索引,你必须顺 ...

  2. mysql中创建唯一索引的关键字_mysql中唯一索引的关键字是什么

    mysql中唯一索引的关键字是unique index.创建唯一索引可以避免数据出现重复.唯一索引可以有多个,但索引列的值必须唯一,索引列的值允许有空值.创建唯一索引可以使用关键字UNIQUE随表一同 ...

  3. mysql唯一索引的关键字_mysql中唯一索引的关键字是什么

    mysql中唯一索引的关键字是unique index.创建唯一索引可以避免数据出现重复.唯一索引可以有多个,但索引列的值必须唯一,索引列的值允许有空值.创建唯一索引可以使用关键字UNIQUE随表一同 ...

  4. mysql索引添加缓慢_mysql 中 创建索引很慢,怎么解决

    引用 如题,我现在 有一张表...里面的数据大概就是 800w 条左右,当然以后也可能会更多,这个表会频繁的更新! 我现在的处理是:每次更新 都会先truncate 这张表(因为里面的数据 已经不需要 ...

  5. oracle 修改索引的名称,Oracle中查询索引名称,批量修改索引名称语句

    在Oralce数据库数据优化过程中,对源数据表处理,原则上是做更名备份,作为被查或回退使用,所以,有修改数据表名后重新建表的操作,这样,往往也需要修改索引.主键.外键名称,方便重建,为了方便.快速生成 ...

  6. oracle 视图能建索引吗,Oracle视图中建立索引注意事项.doc

    Oracle视图中建立索引的注意事项 在视图上创建索引需要三个条件:一.视图必须绑定到架构.要做到这点,在?CREATE?VIEW?语句中,必须加上?WITH?SCHEMABINDING,如果是使用企 ...

  7. oracle 删掉索引,如何清除Oracle中无用索引

    DML性能低下,其中最严重的原因之一是无用索引的存在.所有SQL的插入,更新和删除操作在它们需要在每一行数据被改变时修改大量索引的时候会变得更慢. 许多Oracle 管理人员只要看见在一个SQL 查询 ...

  8. mysql索引排序算法_MySQL中利用索引对数据进行排序的基础教程

    MySQL中,有两种方式生成有序结果集:一是使用filesort,二是按索引顺序扫描.利用索引进行排序操作是非常快的,而且可以利用同一索引同时进行查找和排序操作.当索引的顺序与ORDER BY中的列顺 ...

  9. mysql普通索引自增_mysql中联合索引中的自增列的增长策略

    <深入理解MySQL>中一段介绍MyISAM存储引擎中自动增长列的示例,如下 1 mysql>create table autoincre_demo2 -> (d1 small ...

最新文章

  1. 心中无码,自然高清 | 联合去马赛克与超分辨率研究论文Pytorch复现
  2. 【从零学习OpenCV 4】4种读取Mat类元素的的方法
  3. Java XML解析工具 JDOM介绍及使用实例
  4. 还是分了的好——看惠普、赛门铁克拆分
  5. php attr,PHP DOMAttr isId()用法及代码示例
  6. Linux 防火墙:Netfilter iptables
  7. AUTOSAR从入门到精通100讲(三十四)-AUTOSAR的分层架构
  8. python自动生成word报告_python自动化生成分析报告,让你的工作效率提升10倍+
  9. 软考信息系统项目管理师_管理科学(运筹学)---软考高级之信息系统项目管理师033
  10. 从RSAC2017看威胁情报如何落地
  11. Ubuntu下安装MySQL及简单操作
  12. win10+Linux双系统安装
  13. Java Foundation serial ( 一 )
  14. 力扣解题思路:1419. 数青蛙
  15. 对话论答创始人王枫:“TAD”战法布局AI教育 让每个孩子都能享受优质教育
  16. C++ for循环嵌套 实现 打印10行10列星图
  17. FPGA学习---3.IP核使用,Counter IP核
  18. 了解代码管理系统Git相关产品
  19. win10计算机性能选项在哪,Win10性能大提升,这些设置让你的电脑直接起飞
  20. svm松弛变量与惩罚因子

热门文章

  1. UVA497 Strategic Defense Initiative【LIS+DP】
  2. HDU1272 小希的迷宫【并查集】
  3. Serializable 接口与 Java 序列化与反序列化
  4. 位运算应用及其注意事项
  5. pandas 索引 —— index、set_index、reset_index
  6. Python 标准库 —— urllib(下载进度)
  7. 开课吧里的python学习是真的吗-明星为开课吧直播带货:人人都要学,人人都可以学的Python...
  8. python课程-Python课程
  9. python自动化办公excel-自动化办公:python操作Excel
  10. python的优点有哪些-python的优点和缺点是什么?