主键与聚集索引
索引 主键 聚集
2023-06-13 09:14:11 时间
主键(PRIMARYKEY)
来自MSDN的描述:
表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键(PK),用于强制表的实体完整性。在创建或修改表时,您可以通过定义PRIMARYKEY约束来创建主键。
一个表只能有一个PRIMARYKEY约束,并且PRIMARYKEY约束中的列不能接受空值。由于PRIMARYKEY约束可保证数据的唯一性,因此经常对标识列定义这种约束。
如果为表指定了PRIMARYKEY约束,则SQLServer2005数据库引擎将通过为主键列创建唯一索引来强制数据的唯一性。当在查询中使用主键时,此索引还可用来对数据进行快速访问。因此,所选的主键必须遵守创建唯一索引的规则。
创建主键时,数据库引擎会自动创建唯一的索引来强制实施PRIMARYKEY约束的唯一性要求。如果表中不存在聚集索引或未显式指定非聚集索引,则将创建唯一的聚集索引以强制实施PRIMARYKEY约束。
聚集索引
聚集索引基于数据行的键值在表内排序和存储这些数据行。每个表只能有一个聚集索引,因为数据行本身只能按一个顺序存储。
每个表几乎都对列定义聚集索引来实现下列功能:
可用于经常使用的查询。
提供高度唯一性。
两者的比较
下面是一个简单的比较表
创建表时指定的PRIMARYKEY约束列隐式转换为NOTNULL。
也就是可以列的数据是null
参看最后一项比较
(这一点需要看后面的一个比较,虽然你的数据列可能不唯一,但是系统会替你产生一个你看不到的唯一列)
如果这个表之前没有聚集索引,同时建立主键时候没有强制指定使用非聚集索引,则建立主键时候,同时建立一个唯一的聚集索引
必要时,数据库引擎将向行自动添加一个uniqueifier值,使每个键唯一。此列和列值供内部使用,用户不能查看或访问。
相关文章
- mysql 唯一索引_mysql主键和唯一索引的区别
- 索引是否覆盖例子_数据库索引的概念及作用
- 【已解决】在创建索引库的时候错误提示:
- MySQL索引和主键:提升查询性能的利器(mysql索引主键)
- MySQL在线添加索引:简单便捷的优化方式(mysql在线添加索引)
- 索引深入Mysql:删除唯一索引的技巧(mysql删除唯一)
- MySQL如何查询索引:揭秘终极技巧(mysql如何查询索引)
- MySQL索引:种类与性能优化(mysql索引的种类)
- 优化Oracle数据库速度:索引分区策略(oracle索引分区)
- 如何在Oracle中创建倒序索引?(oracle倒序索引)
- 简单易懂:如何在MySQL中添加表索引(mysql添加表索引)
- MySQL中使用表索引的正确指令(mysql表索引命令)
- Oracle不容忽视:索引不等于全部(oracle不等于索引)
- Oracle主键唯一索引:保证数据完整性(Oracle主键唯一索引)
- MySQL索引强制使用:提升数据库性能(mysql强制使用索引)
- 提高查询效率!实现数据分离!深度解析SQL Server分区索引(sqlserver分区索引)
- 提高MySQL性能的关键!搜索索引优化技巧大揭秘(mysql搜索索引)
- MySQL主键索引语法及作用解析(mysql中主键索引语法)
- MySQL个人信息名词解析字段表行记录主键外键索引视图过程触发器约束查询语句
- 如何在mysql中添加主键索引(mysql中加主键索引)
- Oracle中建立表的主键索引(oracle中给表建主键)
- Oracle数据库主键索引失效案例分析(oracle主键索引失效)
- SQLSERVER聚集索引和主键(PrimaryKey)的误区认识