最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

mysql为什么要索引

来源:懂视网 责编:小采 时间:2020-11-09 08:37:01
文档

mysql为什么要索引

mysql为什么要索引:因为索引能够快速提高查询速度;如果不使用索引,mysql必须从第一条记录开始然后读完整个表直到找出相关的行;表越大花费的时间越多,但也不全是这样;推荐课程:MySQL教程。索引是数据结构;所以,在数据之外,数据库系统还维护着满足特定查找算法的数据结构
推荐度:
导读mysql为什么要索引:因为索引能够快速提高查询速度;如果不使用索引,mysql必须从第一条记录开始然后读完整个表直到找出相关的行;表越大花费的时间越多,但也不全是这样;推荐课程:MySQL教程。索引是数据结构;所以,在数据之外,数据库系统还维护着满足特定查找算法的数据结构
因为索引能够快速提高查询速度;如果不使用索引,mysql必须从第一条记录开始然后读完整个表直到找出相关的行;
表越大花费的时间越多,但也不全是这样;

推荐课程:MySQL教程。

索引是数据结构;

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

索引数据结构分析

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

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

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

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

举例说明索引的工作机制

表A中有两个字段

id,name

表中现在有1000万条数据

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

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

现在根据name建立索引,

索引表结构:

id,name,value

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

然后可以根据排序规则对name进行排序,

根据算法可以直接定位到name在索引表中的位置,

然后就可以取出表A 中的id所在的记录。

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

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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

mysql为什么要索引

mysql为什么要索引:因为索引能够快速提高查询速度;如果不使用索引,mysql必须从第一条记录开始然后读完整个表直到找出相关的行;表越大花费的时间越多,但也不全是这样;推荐课程:MySQL教程。索引是数据结构;所以,在数据之外,数据库系统还维护着满足特定查找算法的数据结构
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top