sqlserver 聚集索引 非聚集索引
聚集索引是一种对磁盘上实际数据重新组织以按指定的一列或者多列值排序。像我们用到的汉语字典,就是一个聚集索引。换句话说就是聚集索引会改变数据库表中数据的存放顺序。
非聚集索引不会重新组织表中的数据,而是对每一行存储索引列值并用一个指针指向数据所在的页面。(一个值指向多行等于该值的数据)。sqlserver默认情况下建立的索引是非聚集索引。非聚集索引在排序时会对所有的取值进行排序,然后快速找到该值对应的所有数据,达到减少排序时间的效果,不需要全表扫描。
聚集索引是直接将所有数据排序后存入表中,所以select * 的时候不需要再进行order by的操作,但是建立一个聚集索引,至少需要相当于该表120%的附加空间,用来存放该表的副本和索引中间页,但是他的性能几乎总是比其他索引要快。
非聚集索引不会对表中数据进行排序,而是进行select * from 表名 order by 字段 的操作时减少排序的时间。
一个表只能有一个聚集索引,但是可以有多个非聚集索引。创建一个表的时候自动为主键生成一个聚集索引。所以无法再生成其他的聚集索引。只能删除主键聚集索引,然后为主键生成非聚集索引,再添加新的聚集索引。
作者:RichardCui
出处:https://www.cnblogs.com/yachao1120/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。该文章也同时发布在我的独立博客中-RichardCuiBlog。