sql 创建一个聚簇索引

sql 创建一个聚簇索引,第1张

楼主给出的语句中,主键列P_no会自动创建聚集索引,一个表中最多只能存在一个聚集索引,所以如果在别的列上建,原来的这个必须删除,或者改为非聚集

新建聚集索引:

CREATE CLUSTERED INDEX fact_idx

ON Salary (fact)

GO

聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此类查询的性能。

非聚集索引通过指针指向数据的存储位置。数据库中一个表只能建议一个聚集索引,对于其余的索引,都要建立非聚集索引。

这里说的聚集索引是聚簇索引吧。。。

聚簇索引即建立在聚簇上的索引,创建聚簇索引时,需要对已有表数据重新进行排序(若表中已有数据),即删除原始的表数据后再将排序结果按物理顺序插回,故聚簇索引建立完毕后,建立聚簇索引的列中的数据已经全部按序排列。

一个表中只能包含一个聚簇索引,但该索引可以包含多个列。

B-树索引中,聚簇索引的叶层就是数据页。

非聚簇索引类似书本索引,索引与数据存放在不同的物理区域,建立非聚簇索引时数据本身不进行排序。一个表中科含多个非聚簇索引。

B-树索引中,非聚簇索引的叶层仍是索引页,其以指针指向数据页实际存储位置。

唯一性索引保证表中没有两行在定义索引的列上具有重复值,ORACLE自动为主键和唯一键列创建唯一索引;主键本身就是唯一索引,反之不成立(唯一索引允许一个NULL值),唯一性索引比非唯一性索引效率高,故在一般情况下,在无重复值的列上应尽量建立唯一性索引。

若为谋个表的某个列创建了唯一索引,则即使这个列没有唯一值约束,也会被强制限制不能插入重复记录。

这样回答LZ满意么?


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/10055943.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存