一、添加约束的语法
alter table 表名 add constraint 约束名 约束类型 具体的约束说明
- use studentmanagedb
- go
- --添加约束,创建主键约束
- if exists(select * from sysobjects where name='pk_StudentId')
- alter table Students drop constraint pk_StudentId
- alter table Students add constraint pk_StudentId primary key(StudentId)
- --添加约束,创建唯一约束
- if exists(select * from sysobjects where name='uq_StudentIdNo')
- alter table Students drop constraint uq_StudentIdNo
- alter table Students add constraint uq_StudentIdNo unique(StudentIdNo)
- --添加约束,创建检查约束
- if exists(select * from sysobjects where name='ck_Age')
- alter table Students drop constraint ck_Age
- alter table Students add constraint ck_Age check(Age between 18 and 26)
- if exists(select * from sysobjects where name='ck_PhoneNumber')
- alter table Students drop constraint ck_PhoneNumber
- alter table Students add constraint ck_PhoneNumber check(len(PhoneNumber)=11)
- --创建外键约束
- if exists(select * from sysobjects where name='fk_ClassId')
- alter table Students drop constraint fk_ClassId
- alter table Students add constraint fk_ClassId foreign key(ClassId) references StudentClass(ClassId)
实体完整性
a. 能够唯一标识表中的每一条记录。
b. 实现方式:主键、唯一键、IDENTITY 属性。
域完整性
a. 表中特定列数据的有效性,确保不会输入无效的值。
b. 实现方式:数据类型限制、缺省值、非空值。
引用完整性
a. 维护表间数据的有效性、完整性。
b. 实现方式:建立外键,关联另一表的主键。
主键的选择
a. 最少性原则:尽量选择单个键作为主键。
b. 稳定性原则:尽量选择数值更新少的列作为主键。
外键使用
a. 要求数据类型、数据长度必须与对应的主键表字段完全一致。
b. 添加数据时,要首先添加主键表,在添加外键表。
c. 删除数据时,要首先删除外键表数据,在删除主键表数据。
完整数据库创建步骤
建库 ----> 建表 ----> 主键约束 ----> 域完整性约束 ----> 外键约束
插入数据的过程
验证主键、主外键关系、检查约束……----> 插入成功
来源: http://www.bubuko.com/infodetail-1958492.html