好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

SQL Server主键约束(PRIMARY KEY)

SQL Server PRIMARY KEY(主键)约束简介

主键是唯一标识表中每一行的一列或一组列。您可以使用主键约束为表创建主键。
如果主键仅包含一列,你可以使用 PRIMARY KEY 约束作为列约束:

CREATE TABLE table_name (
    pk_column data_type PRIMARY KEY,
    ...
);

如果主键有两列或多列,则必须将主键约束用作表约束:

CREATE TABLE table_name (
    pk_column_1 data_type,
    pk_column_2 data type,
    ...
    PRIMARY KEY (pk_column_1, pk_column_2)
);

每个表只能包含一个主键,一个主键可以包含多个列,即多个列的组合不能重复。参与主键的所有列必须定义为 NOT NU 编程客栈 LL 。如果未为所有主键列指定 NOT NULL 约束,SQL Server会自动为这些列设置非空约束。

SQL Server PRIMARY KEY约束示例

以下示例创建了一个具有主键的 www.cppcns.com 表,主键由一列组成:

CREATE TABLE dbo.activitie OdAvRrTCQ s (
    activity_id INT PRIMARY KEY IDENTITY,--主键
    activity_name VARCHAR (255) NOT NULL,
    activity_date DATE NOT NULL
);

在表 dbo.activities 中, activity_id 列是主键列,意味着这一列的值不能重复

IDENTITY 属性用于 activity_id 列自动生成唯一的整数值。

下面创建一个由两列组成外键的新表:

CREATE TABLE dbo.participants(
    activity_id int,
    customer_id int,
    PRIMARY KEY(acti http://www.cppcns.com vity_id, customer_id)
);

在本例中, activity_id 或 customer_id 列中的值可以重复,但两列中的每个值组合都必须是唯一的。

通常,表总是在创建时定义主键。然而,有时,现有表可能没有定义主键。在这种情况下,可以使用 ALTER 编程 TABLE 语句向表中添加主键。比如示例:

先创建一个没有主键列的表:

CREATE TABLE dbo.events(
    event_id INT NOT NULL,
    event_name VARCHAR(255),
    start_date DATE NOT NULL,
    duration DEC(5,2)
);

然后使 event_id 列成为主键:

ALTER TABLE sales.events 
ADD PRIMARY KEY(event_id);

注意,如果  sales.events  表已经有数据,在将  event_id  列提升为主键之前,必须确保  event_id  中的值是不重复的。

到此这篇关于SQL Server主键约束(PRIMARY KEY)的文章就介绍到这了,更多相关SQL Server主键约束内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

查看更多关于SQL Server主键约束(PRIMARY KEY)的详细内容...

  阅读:35次