分享更有价值
被信任是一种快乐

MySQL中的索引是什么

文章页正文上

这篇文章将为大家详细讲解有关MySQL中的索引是什么,小免费主机域名编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。对于高级开发,我们经常要编写一些复杂的sql,那么防止写出低效sql,我们有必要了解一些索引的基础知识。通过这些基础知识我们可以写出更高效的sql。01 索引的优点大大减少服务器需要扫描的数据量,也就是IO量帮助服务器避免排序和临时表(尽量避免文件排序,而是使用索引排序)将随机IO变成顺序IO02 索引的用处快速查找匹配where子句中的行如果可以在多个索引中选择,mysql通常会使用找到最少行的索引如果表具有多列索引,则优化器可以使用索引的任何最左前缀来查找行当有表连接的时候,从其他表检索行数据查找特定索引列的min和max的值如果排序或者分组时可用索引的最左前缀完成的,则对表进行排序和分组在某些情况下,可以优化查询以检索数据值而无需查找数据行03 索引的分类数据库默认建立的索引是给唯一键建立的主键索引(唯一且非空)唯一索引(唯一可为空)普通索引(普通字段的索引)全文索引(一般是varchar,char,text类型建立的,但很少用)组合索引(多个字的建立的索引)04 索引的技术名词1. 回表name字段是普通索引,从name列的B+树找到主键,再从主键的B+树找到最终的数据,这就是回表。(主键索引的叶子节点保存的是列的所有数据,但是普通所有的叶子结点保存的是对应的主键ID)如图:一个use表中name建立的索引结构sql是select * from use where name='sun'首先会通过name这个非主键索引找到sun对应的主键Id=2,然后通过id=2在主键索引中找到整个行数据,并返回,这个就是回表。2. 覆盖索引在非主键索引上可以查询到所需要的字段,不需要回表再次查询就叫覆盖索引。如上图name索引,sql是 select id,name from user where name ="1" ,id的值在第一步非主键索引就已经有了,就不需要根据ID到主键索引中查询行数据了。3. 最左匹配组合索引中 先匹配左边,再继续向后匹配;比如user表中有name+age组成的联合索引,select * from user where name=”纪先生” and age = 18 就符合最左匹配,可以用的索引。而select * from user where age = 18就不符合,用不到这个索引。扩展;如果是下面两个sql怎么建立索引由于最左匹配原则:只需要建立一个组合索引age+name即可如果是下面三个sql呢建立name+age和age索引,或者建立age+name和name索引,看着两个都可以。其实name+age和age更好,因为索引也是需要持久化存储的,占用磁盘空间,读取的时候也是占用内存的,name+age和age+name这两个占用是一样的,但是name和age单独比较,肯定age占用空间更少,name更长(索引越大,IO次数可能更多)注意!注意!注意!:在看很多文章的时候,经常看到一些对于最左匹配错误的举例:如果索引是name+age的组合索引,sql是select * from user where age = 18 and name="纪先生"很多人认为这种是不能走索引,实际上可以的。mysql的优化器会优化调整顺序的,调整成 name=”纪先生” and age = 184. 索引下推组合索引中尽量利用索引信息,来尽可能的减少回表的次数案例:还是 name+age的组合索引如果没有索引下推的查询是 在组合索引中通过name查询所有匹配的数据,然后回表根据ID查询对于的数据行,之后在筛选出符合age条件的数据。索引下推就是组合索引中通过name查询匹配再根据age找到符合的数据ID,然后回表根据ID查询对应行数据,明显会减少数据的条数05 索引匹配方式mysql官网准备了一些学习测试的数据库,可以直接下载通过source导入到我们自己的数据库官网地址:dev.mysql.com/doc/index-o…如上图下载zip, 其中包含了sakila-schema.sql和sakila-data.sql,分别是sakila的库,表和数据的创建脚本。需要通过explain来查看索引的执行情况,执行计划以前有文章详细讲过,具体参考执行计划explain1. 全值匹配指和某个索引中的所有列进行匹配,例如使用数据库sakila中的staff表新建一个三个字段的联合索引:执行sql:其中的ref是三个const免费主机域名, 用到三个字段,能全匹配一条数据2. 最左前缀匹配只匹配组合索引中前面几个字段执行sql:ref只出现2个const,比上面全值匹配少一个,就只匹配了前面两个字段3. 匹配列前缀可以匹配某一列的的开头部分,像like属性执行sql:type=range ,是个范围查询,可以匹配一个字段的一部分,而不需要全值匹配如果有模糊匹配的字段不要放在索引的最前面,否则有索引也不能使用,如下4. 匹配一个范围值可以查找某一个范围的数据5. 精确匹配某一列并范围匹配另一列可以查询第一列的全部和另一列的部分6. 只访问索引的查询查询的时候只需要访问索引,不需要访问数据行,其实就是索引覆盖extra=Using index 说明是使用了索引覆盖,不需要再次回表查询。其实一张表中有索引并不总是最好的。总的来说,只有当索引帮助存储引擎快速提高查找到记录带来的好处大于其带来的额外工作时,索引才是有效的。对应很小的表,大部分情况下没有索引,全表扫描更高效;对应中大型表,索引时非常有效的;但是对于超大的表,索引的建立和使用代价也就非常高,一般需要单独处理特大型的表,例如分区,分库,分表等。关于“MySQL中的索引是什么”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

相关推荐: MySQL搭建主从报错“The server is not configured as slave“怎么解决

这篇文章主要介绍“MySQL搭建主从报错“The server is not configured as slave“怎么解决”,在日常操作中,相信很多人在MySQL搭建主从报错“The server is not configured as slave“怎么…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册