mysql为什么要索引


本文摘自PHP中文网,作者(*-*)浩,侵删。

因为索引能够快速提高查询速度;如果不使用索引,mysql必须从第一条记录开始然后读完整个表直到找出相关的行;
表越大花费的时间越多,但也不全是这样。

推荐课程:MySQL教程

索引是数据结构;

所以,在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法。这种数据结构,就是索引。

索引数据结构分析

这个索引是个啥结构呢?换句话说,为啥这个结构就能提高检索速度呢?

1、若没有索引,搜索某个记录时(例如查找name='wish')需要搜索所有的记录,因为不能保证只有一个wish,必须全部搜索一遍.

2、若在name上建立索引,mysql会对全表进行一次搜索,将每条记录的name值查找升序排列,然后构建索引条目(name和row_id),存储到索引段中,查询name为wish时即可直接查找对应地方.

3、创建了索引并不一定就会使用,mysql自动统计表的信息后,决定是否使用索引,表中数据很少时使用全表扫描速度已经很快,没有必要使用索引。

举例说明索引的工作机制

表A中有两个字段

id,name

表中现在有1000万条数据

需求:根据name查询出对应的id

如果没有索引,那就得查询表中所有记录,就得把1000万条数据都得挨个查一遍,你说慢不慢。

现在根据name建立索引,

索引表结构:

1

id,name,value

其中value是表A的id,以json数组的方式存放(因为会有多个name相同的情况存在);

然后可以根据排序规则对name进行排序,根据算法可以直接定位到name在索引表中的位置,然后就可以取出表A 中的id所在的记录。

简而言之,就是通过建立索引,可以直达表A中的记录。

当然快了,想必须查询表A要查询1000万条数据,通过建立索引,以算法大大减少了查询量。

以上就是mysql为什么要索引的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql源码是什么语言

mysql详解如何优化查询条件

mysql如何让外网访问

如何备份和还原mysql数据库?

mysql8.0修改密码的正确姿势分享

mysql 出现1071错误怎么办

mysql中关于prepare原理的详解

mysql支持的数据类型的详细介绍

mysql怎么建库

mysql怎么查看表结构?

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...