全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

为什么索引过的字段排序速度会很快,原理是什么?

发布时间:2023-10-13 05:45:41
发布人:xqq

一、为什么索引过的字段排序速度会很快

1、索引是对数据库表中一列或多列的值进行排序的一种结构,本身是一个有序键值列表。这样检索的数据直接可以以顺序列出。

2、通常来说,索引比要检索或者排序的表本身小很多,足够放在内存中或者一次性读取,确定了数据位置,直接读取磁盘上相应的数据块,以减少磁盘I/O,对现在的计算机来说,磁盘I/O的开销很大。如果没有索引,排序一般需要全表扫描,大大增加磁盘I/O。

但索引本身也是表,因此会占用存储空间,一般来说,索引表占用的空间的数据表的1.5倍;索引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除,添加,修改)的效率,因为在修改数据表的同时还需要修改索引表。

延伸阅读:

二、全文索引

FULLTEXT(全文)索引,仅可用于MyISAM和InnoDB,针对较大的数据,生成全文索引非常的消耗时间和空间。对于文本的大对象,或者较大的CHAR类型的数据,如果使用普通索引,那么匹配文本前几个字符还是可行的,但是想要匹配文本中间的几个单词,那么就要使用LIKE %word%来匹配,这样需要很长的时间来处理,响应时间会大大增加,这种情况,就可使用时FULLTEXT索引了,在生成FULLTEXT索引时,会为文本生成一份单词的清单,在索引时及根据这个单词的清单来索引。FULLTEXT可以在创建表的时候创建,也可以在需要的时候用ALTER或者CREATE INDEX来添加。

#it技术干货

相关文章

html的lang属性有什么用?

html的lang属性有什么用?

2023-10-13
手机APP定制开发与模板开发相比具有哪些优势?

手机APP定制开发与模板开发相比具有哪些优势?

2023-10-13
一个大型的SNS网站,是否适合数据库全部用mongodb来做,为什么?

一个大型的SNS网站,是否适合数据库全部用mongodb来做,为什么?

2023-10-13
APP中集成移动端车牌识别系统都能达到什么效果?

APP中集成移动端车牌识别系统都能达到什么效果?

2023-10-13

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取