文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql要索引的原因

2024-04-02 19:55

关注

这篇文章主要介绍了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万条数据,通过建立索引,以算法大大减少了查询量。


感谢你能够认真阅读完这篇文章,希望小编分享mysql要索引的原因内容对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,遇到问题就找亿速云,详细的解决方法等着你来学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯