SQL Server主键/索引/唯一约束各名词联系与区别

本文详细介绍了SQL Server中的主键、唯一约束和不同类型的索引,包括它们之间的联系与区别。主键是表的唯一标识,不允许重复且不能为空;唯一约束同样保证唯一性,但允许NULL值。主键自动带有唯一约束。索引则用于加速查询,分为唯一索引、主键索引、聚集索引和非聚集索引,其中聚集索引决定了数据的物理排序,而非聚集索引则包含指向数据存储位置的指针。
摘要由CSDN通过智能技术生成

首先说下主键:PRIMARY KEY 约束唯一标识数据库表中的每条记录。唯一性是主键最主要的特性,主键不能有重复值。主键列不能包含 NULL 值。每个表都应该有一个主键,并且每个表只能有一个主键(可以是多个列为一个主键)。

唯一约束(Unique Constraint):约束唯一标识数据库表中的每条记录,确保表中的某一列或者复合列数据没有相同的值。

UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。PRIMARY KEY 拥有自动定义的 UNIQUE 约束。请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。

下面是创建约束的SQL:

--创建表时定义约束
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
);

--表已被创建,可以通过修改表增加约束
ALTER TABLE Persons ADD UNIQUE (Id_P);

--可以定义多个列的UNIQUE约束并命名
ALTER TABLE Persons ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName);

索引

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值