mysql要索引的原因


这篇文章主要介绍了mysql要索引的原因,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。因为索引能够快速提高查询速度;如果不使用索引,mysql必须从第一条记录开始然后读完整个表直到找出相关的行;
表越大花费的时间越多,但也不全是这样;索引是数据结构;所以,在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法。这种数据结构,就是索引。索引数据结构分析这个索引是个啥结构呢?换句话说,为啥这个结构就能提高检索速度呢?若没有索引,搜索某个记录时(例如查找name=’wish’)需要搜索所有的记录,因为不能保证只有一个wish,必须全部搜索一遍.若在name上建立索引,mysql会对全表进行一次搜索,将每条记录的name值查找升序排列,然后构建索引条目(name和row_id),存储到索引段中,查询name为wish时即可直接查找对应地方.3.创建了索引并不一定就会使用,mysql自动统计表的信息后,决定是否使用索引,表中数据很少时使用全表扫描速度已经很快,没有必开发云主机域名要使用索引.举例说明索引的工作机制表A中有两个字段id,name表中现在有1000万条数据需求:根据name查询出对应的id如果没有索引,那就得查询表中所有记录,就得把1000万条数据都得挨个查一遍,你说慢不慢。现在根据name建立索引,索引表结构:其中value是表A的id,以json数组的方式存放(因为会有多个name相同的情况存在);然后可以根据排序规则对name进行排序,根据算法可以直接定位到name在索引表中的位置,然后就可以取出表A 中的id所在的记录。简而言之,就是通过建立索引,可以直达表A中的记录。当然快了,想必须查询表A要查询1000万条数据,通过建立索引,以算法大大减少了查询量。
感谢你能够认真阅读完这篇文章,希望小编分享mysql要索引的原因内容对大家有帮助,同时也希望大家多多支持开发云,关注开发云行业资讯频道,遇到问题就找开发云,详细的解决方法等着你来学习!

相关推荐: 使用innobackup实现 基于GTID的从库搭建

对于较大的数据库,我们一般都是使用innobackup进行备份,备份的及恢复的速度更快。试验环境: CentOS6.8 x86_64 MySQL5.6.34 社区rpm版xtrabackup版本:percona-xtrabackup-24-2.4.5-1.el…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/12 08:36
下一篇 06/12 08:36

相关推荐