久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

SQL Server主鍵約束(PRIMARY KEY)

瀏覽:42日期:2023-03-06 14:25:39
目錄
  • SQL Server PRIMARY KEY(主鍵)約束簡(jiǎn)介
  • SQL Server PRIMARY KEY約束示例

SQL Server PRIMARY KEY(主鍵)約束簡(jiǎn)介

主鍵是唯一標(biāo)識(shí)表中每一行的一列或一組列。您可以使用主鍵約束為表創(chuàng)建主鍵。
如果主鍵僅包含一列,你可以使用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)
);

每個(gè)表只能包含一個(gè)主鍵,一個(gè)主鍵可以包含多個(gè)列,即多個(gè)列的組合不能重復(fù)。參與主鍵的所有列必須定義為NOT NULL。如果未為所有主鍵列指定NOT NULL約束,SQL Server會(huì)自動(dòng)為這些列設(shè)置非空約束。

SQL Server PRIMARY KEY約束示例

以下示例創(chuàng)建了一個(gè)具有主鍵的表,主鍵由一列組成:

CREATE TABLE dbo.activities (
    activity_id INT PRIMARY KEY IDENTITY,--主鍵
    activity_name VARCHAR (255) NOT NULL,
    activity_date DATE NOT NULL
);

在表dbo.activities中,activity_id列是主鍵列,意味著這一列的值不能重復(fù)

IDENTITY屬性用于activity_id列自動(dòng)生成唯一的整數(shù)值。

下面創(chuàng)建一個(gè)由兩列組成外鍵的新表:

CREATE TABLE dbo.participants(
    activity_id int,
    customer_id int,
    PRIMARY KEY(activity_id, customer_id)
);

在本例中,activity_idcustomer_id列中的值可以重復(fù),但兩列中的每個(gè)值組合都必須是唯一的。

通常,表總是在創(chuàng)建時(shí)定義主鍵。然而,有時(shí),現(xiàn)有表可能沒(méi)有定義主鍵。在這種情況下,可以使用ALTER TABLE語(yǔ)句向表中添加主鍵。比如示例:

先創(chuàng)建一個(gè)沒(méi)有主鍵列的表:

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 表已經(jīng)有數(shù)據(jù),在將 event_id 列提升為主鍵之前,必須確保 event_id 中的值是不重復(fù)的。

到此這篇關(guān)于SQL Server主鍵約束(PRIMARY KEY)的文章就介紹到這了,更多相關(guān)SQL Server主鍵約束內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MsSQL
主站蜘蛛池模板: 昭觉县| 磴口县| 休宁县| 虹口区| 县级市| 青浦区| 三亚市| 栾川县| 乌海市| 安国市| 亚东县| 康马县| 肇州县| 华宁县| 五台县| 崇信县| 太康县| 临洮县| 白沙| 辽阳市| 麻城市| 大邑县| 贵阳市| 普安县| 麻江县| 姚安县| 雷波县| 自贡市| 晴隆县| 鹤山市| 安塞县| 都江堰市| 班戈县| 贵港市| 淄博市| 双鸭山市| 图片| 宁阳县| 都安| 桂林市| 长丰县|