欢迎您 本站地址:  

SQL UNIQUE 约束

UNIQUE 约束在 SQL 中用于确保一列或多列中的所有值都是唯一的,这意味着在约束应用的列中不能有重复的值。

UNIQUE 类似于主键 (PRIMARY KEY) 约束,但 UNIQUE 约束允许列中的值为 NULL,而主键不允许。

PRIMARY KEY 约束自带唯一性(UNIQUE)约束功能。

每个表可以有多个 UNIQUE 约束,但只能定义一个 PRIMARY KEY 约束。

使用场景


CREATE TABLE 时的 SQL UNIQUE 约束

在创建表时,可以在特定列或多个列上定义 UNIQUE 约束,以确保这些列中的值在表内唯一。

在 "Persons" 表的 P_Id 列上添加 UNIQUE 约束

MySQL:

CREATE TABLE Persons (
    P_Id INT NOT NULL,
    LastName VARCHAR(255) NOT NULL,
    FirstName VARCHAR(255),
    Address VARCHAR(255),
    City VARCHAR(255),
    UNIQUE (P_Id)
);

SQL Server / Oracle / MS Access:

CREATE TABLE Persons (
    P_Id INT NOT NULL UNIQUE,
    LastName VARCHAR(255) NOT NULL,
    FirstName VARCHAR(255),
    Address VARCHAR(255),
    City VARCHAR(255)
);

UNIQUE 约束并在多列上定义

如需为 UNIQUE 约束指定名称,并在多个列上应用,可以使用以下语法:

MySQL / SQL Server / Oracle / MS Access:

CREATE TABLE Persons (
    P_Id INT NOT NULL,
    LastName VARCHAR(255) NOT NULL,
    FirstName VARCHAR(255),
    Address VARCHAR(255),
    City VARCHAR(255),
    CONSTRAINT uc_PersonID UNIQUE (P_Id, LastName)
);

在 ALTER TABLE 时添加 UNIQUE 约束

如果表已存在,可以使用 ALTER TABLE 语句在指定列上添加 UNIQUE 约束。

在 "P_Id" 列上添加 UNIQUE 约束

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD UNIQUE (P_Id);

命名 UNIQUE 约束并在多列上应用

如需命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束,请使用下面的 SQL 语法:

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD CONSTRAINT uc_PersonID UNIQUE (P_Id, LastName);


删除 UNIQUE 约束

如果需要移除一个 UNIQUE 约束,可以使用以下 SQL 语句:

MySQL:

ALTER TABLE Persons
DROP INDEX uc_PersonID;

SQL Server / Oracle / MS Access:

ALTER TABLE Persons
DROP CONSTRAINT uc_PersonID;
小库提示

扫描下方二维码,访问手机版。