SQL Server中聚集索引和非聚集索引的区别有哪些?

聚集索引与非聚集索引的根本区别是表记录的物理排序顺序和索引的排序顺序是否一致。其主要区别有以下几点:

  1. 聚集索引一个表只能有一个,非聚集索引一个表可以存在多个。

  2. 聚集索引存储记录是物理上连续存在,物理存储按照索引排序;而非聚集索引是逻辑上的连续,物理存储并不连续,物理存储不按照索引排序。

  3. 聚集索引查询数据比非聚集索引速度快,插入数据速度慢(时间花费在「物理存储的排序」上,也就是首先要找到位置然后插入);非聚集索引反之。

  4. 索引是通过B+Tree的结构来描述的,聚集索引的叶节点就是数据节点,而非聚集索引的叶节点仍然是索引节点,只不过有一个指针指向对应的数据块。

聚集索引和非聚集索引的使用场景

动作描述

聚集索引

非聚集索引

列经常被分组或排序

返回某范围内的数据

一个或极少不同值

小数目的不同值

大数目的不同值

频繁更新的列

外键列

主键列

频繁修改索引列

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值