(1)NOT NULL约束强制列不接受NULL 值。如果不向字段添加值,就无法插入新记录或者更新记录。 (2)UNIQUE 约束唯一标识数据库表中的每条记录。 CREATE TABLE Persons (Id_P int NOT NULL, LastName varchar(255) NOT NULL, UNIQUE (Id_P))创建unique CONSTRAINT uc_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) NOT NULL, City varchar(255), PRIMARY KEY (Id_P)创建主键约束 CONSTRAINT uc_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 int NOT NULL, Id_P int, FOREIGN KEY (Id_P) REFERENCES Persons(Id_P))在 "Orders" 表创建时为 "Id_P" 列创建 FOREIGN KEY: 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约束 CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')重命名约束 在表已经存在的情况下,添加约束ALTER TABLE Persons ADD CHECK (Id_P>0) 重命名约束ALTER TABLE Persons ADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes') 撤销约束ALTER TABLE Persons DROP CHECK chk_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 撤销