• 首页
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案
目录

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

因为索引是对数据库表中一列或多列的值进行排序的一种结构,本身是一个有序键值列表。这样检索的数据直接可以以顺序列出。通常来说,索引比要检索或者排序的表本身小很多,足够放在内存中或者一次性读取。

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

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

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

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

延伸阅读:

二、全文索引

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

相关文章