为什么索引过的字段排序速度会很快,原理是什么?
一、为什么索引过的字段排序速度会很快
1、索引是对数据库表中一列或多列的值进行排序的一种结构,本身是一个有序键值列表。这样检索的数据直接可以以顺序列出。
2、通常来说,索引比要检索或者排序的表本身小很多,足够放在内存中或者一次性读取,确定了数据位置,直接读取磁盘上相应的数据块,以减少磁盘I/O,对现在的计算机来说,磁盘I/O的开销很大。如果没有索引,排序一般需要全表扫描,大大增加磁盘I/O。
但索引本身也是表,因此会占用存储空间,一般来说,索引表占用的空间的数据表的1.5倍;索引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除,添加,修改)的效率,因为在修改数据表的同时还需要修改索引表。
延伸阅读:
二、全文索引
FULLTEXT(全文)索引,仅可用于MyISAM和InnoDB,针对较大的数据,生成全文索引非常的消耗时间和空间。对于文本的大对象,或者较大的CHAR类型的数据,如果使用普通索引,那么匹配文本前几个字符还是可行的,但是想要匹配文本中间的几个单词,那么就要使用LIKE %word%来匹配,这样需要很长的时间来处理,响应时间会大大增加,这种情况,就可使用时FULLTEXT索引了,在生成FULLTEXT索引时,会为文本生成一份单词的清单,在索引时及根据这个单词的清单来索引。FULLTEXT可以在创建表的时候创建,也可以在需要的时候用ALTER或者CREATE INDEX来添加。

相关推荐HOT
更多>>
MySQL中id通常使用什么数据类型呢?
一、MySQL中id通常使用什么数据类型一般都是 int 自增设置为主键如果表大的话可以设置为 龙, 或者big int例如:‘id’int unsigned not null a...详情>>
2023-10-15 22:12:14
关系型数据库是什么?
一、什么是关系型数据库关系型数据库是按照关系模型组织和存储数据的数据库。它使用表格(表)的形式来表示和存储数据,每个表代表一个实体,而...详情>>
2023-10-15 21:32:39
设计移动端表单有哪些注意事项?
1、分布式表单iPhone目前主要的机型屏幕尺寸在4.7-5.8英寸,android的尺寸更多一些,但是总体上来说,移动端的载体手机屏幕不大,能承载的信息...详情>>
2023-10-15 21:06:48
APP开发过程中需要注意什么?
一、APP开发过程中需要注意什么1、了解需求:商家和企业在开发app的时候,首先要了解市场需求,也就是用户的需求,这点是最重要的,想要app软件...详情>>
2023-10-15 20:00:34热门推荐
为什么索引过的字段排序速度会很快,原理是什么?
沸为什么Python开发世界持续被Django统治那么久?
热Binder到底是什么?
热MySQL中id通常使用什么数据类型呢?
新关系型数据库是什么?
设计移动端表单有哪些注意事项?
开发一个生鲜商城APP软件可以解决哪些问题?
APP开发过程中需要注意什么?
图数据库的应用有哪些优点?
数据库中的视图有什么用?
数据库丢失数据的原因是什么?
Mysql、SQLite、Mongo的区别?
LayoutInflater.inflate()方法两个参数和三个参数的区别?
为什么要用flow?
技术干货






