千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:郑州千锋IT培训  >  技术干货  >  为什么索引过的字段排序速度会很快,原理是什么?

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

来源:千锋教育
发布人:xqq
时间: 2023-10-15 23:56:18

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

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

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

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

延伸阅读:

二、全文索引

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

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

Binder到底是什么?

2023-10-15

图数据库的应用有哪些优点?

2023-10-15

数据库中的视图有什么用?

2023-10-15

最新文章NEW

为什么Python开发世界持续被Django统治那么久?

2023-10-15

数据库丢失数据的原因是什么?

2023-10-15

为什么要用flow?

2023-10-15

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>