轻松上手,快乐学习!

SQL CHECK 约束


SQL CHECK 约束

CHECK约束用于限制列中的值范围。

如果在单个列上定义CHECK约束,则它仅允许此列的某些值。

如果在表上定义CHECK约束,它可以根据行中其他列中的值限制某些列中的值。


SQL CHECK CREATE TABLE

当创建“Persons”表时,以下SQL在“Age”列上创建CHECK约束.CHECK约束确保您不能拥有18岁以下的任何人:

MySQL的:

CREATE TABLE Persons(
    ID int NOT NULL,
   LastName varchar(255) NOT NULL,
   FirstName varchar(255),
   Age int,
   CHECK (Age>=18)
);

SQL Server / Oracle / MS Access:

CREATE TABLE Persons(
    ID int NOT NULL,
   LastName varchar(255) NOT NULL,
   FirstName varchar(255),
   Age int CHECK (Age>=18)
);

要允许命名CHECK约束,并在多列上定义CHECK约束,请使用以下SQL语法:

MySQL / SQL Server / Oracle / MS Access:

CREATE TABLE Persons(
    ID int NOT NULL,
   LastName varchar(255) NOT NULL,
   FirstName varchar(255),
   Age int,
   City varchar(255),
   CONSTRAINT CHK_Person CHECK (Age>=18 AND City='Sandnes')
);

SQL CHECK ALTER TABLE

在已创建表时在“Age”列上创建CHECK约束,请使用以下SQL:

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD CHECK (Age>=18);

要允许命名CHECK约束,并在多列上定义CHECK约束,请使用以下SQL语法:

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD CONSTRAINT CHK_PersonAge CHECK (Age>=18 AND City='Sandnes');

DROP CHECK约束

要删除CHECK约束,请使用以下SQL:

SQL Server / Oracle / MS Access:

ALTER TABLE Persons
DROP CONSTRAINT CHK_PersonAge;

MySQL的:

ALTER TABLE Persons
DROP CHECK CHK_PersonAge;