SQL 约束
约束用于限制加入表的数据的类型。
可以在创建表时规定约束(通过 CREATE TABLE 语句),或者在表创建之后也可以(通过 ALTER TABLE语句)。
(1)NOT NULL约束强制列不接受NULL 值。如果不向字段添加值,就无法插入新记录或者更新记录。
(2)UNIQUE 约束唯一标识数据库表中的每条记录。
CREATE TABLE Persons
(Id_P int NOT NULL,
LastNamevarchar(255) NOT NULL,
UNIQUE (Id_P))创建unique
CONSTRAINTuc_PersonID UNIQUE (Id_P,LastName)命名unique约束
当表已被创建时,如需在 "Id_P" 列创建 UNIQUE 约束
ALTER TABLE Persons
ADD CONSTRAINT uc_PersonID UNIQUE(Id_P,LastName)创建unique
ADD CONSTRAINT uc_PersonID UNIQUE(Id_P,LastName)命名unique并定义多列的约束
DROP INDEX uc_PersonID撤销unique约束
(4)PRIMARY KEY 拥有自动定义的 UNIQUE 约束。
每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY约束。
PRIMARY KEY约束唯一标识数据库表中的每条记录。
主键必须包含唯一的值。
主键列不能包含 NULL 值。
每个表都应该有一个主键,并且每个表只能有一个主键。
CREATE TABLE Persons
(Id_P int NOT NULL,
LastName varchar(255) NOTNULL,
City varchar(255),
PRIMARY KEY (Id_P)创建主键约束
CONSTRAINTuc_PersonID PRIMARY KEY (Id_P,LastName)命名主键约束
ALTER TABLE Persons
ADD PRIMARY KEY (Id_P)如果在表已存在的情况下为 "Id_P" 列创建PRIMARY KEY 约束
ADD CONSTRAINT pk_PersonID PRIMARY KEY(Id_P,LastName)命名约束,并且为多列定义 约束 DROP PRIMARY KEY撤销约束)一旦确定为主键,则该字段不可为空也不可以重复。
(5)FOREIGN KEY 一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY。
CREATE TABLE Orders
(O_Id intNOT NULL,
Id_Pint,
FOREIGN KEY(Id_P) REFERENCES Persons(Id_P))在 "Orders" 表创建时为 "Id_P" 列创建 FOREIGNKEY:
CONSTRAINT fk_PerOrders FOREIGN KEY(Id_P)REFERENCES Persons(Id_P)命名、多列
如果在 "Orders" 表已存在的情况下为 "Id_P" 列创建 FOREIGN KEY 约束
ALTER TABLE Orders
ADD FOREIGN KEY (Id_P)
REFERENCES Persons(Id_P) 创建
ALTER TABLE Orders
DROP FOREIGN KEY fk_PerOrders 撤销
(6)CHECK 约束用于限制列中的值的范围。
如果对单个列定义CHECK 约束,那么该列只允许特定的值。
如果对一个表定义CHECK 约束,那么此约束会在特定的列中对值进行限制。
CHECK(Id_P>0)创建check约束
CONSTRAINTchk_Person CHECK (Id_P>0 AND City='Sandnes')重命名约束
在表已经存在的情况下,添加约束ALTER TABLE Persons ADD CHECK(Id_P>0)
重命名约束ALTER TABLE Persons ADD CONSTRAINTchk_Person CHECK (Id_P>0 AND City='Sandnes')
撤销约束ALTER TABLE Persons DROP CHECKchk_Person
(7)DEFAULT DEFAULT 约束用于向列中插入默认值。
如果没有规定其他的值,那么会将默认值添加到所有的新记录。
City varchar(255) DEFAULT'Sandnes'创建约束
如果在表已存在的情况下为 "City" 列创建DEFAULT 约束
ALTER TABLE Persons
ALTER City SET DEFAULT'SANDNES'创建
ALTER TABLE Persons
ALTER City DROP DEFAULT 撤销
|
|