1.主键约束(primary key)
不允许重复元素,并且不能为空,避免了数据冗余,
实例演示:
create table dept
(
dept_id int constraint pk_dept_id_ID primary key, --在dept表中创建一个名为dept_id的列,并设为主键,主键名称命名为pk_dept_id_ID
dept_name nvarchar(10), --在dept表中创建一个名为dept_name的列,最多可以放10个字符
dept_address nvarchar(30) --在dept表中创建一个名为dept_address nvarchar(30)
)
insert into dept values(1,'研发部','北京')
insert into dept(dept_id,dept_name,dept_address)values(2,'市场部','北京')
删除主键约束
alter table dept dropconstraint pk_dept_id_ID
添加主键约束
alter table dept add constraint pk_dept_id_ID primary key(dept_id)
2.外键约束(foreign key)
解释:通过外键约束从语法上保证了事物所关联的其它事物一定是存在的,事物和事物之前的关系是通过外键来体现的
实例演示:
create table emp
(
emp_id int primary key,
--在emp表中构造一个名字叫做emp_id的属性(列)
--并且把它设为主键(primary key)
emp_name nvarchar(20),
emp_sex nchar(1),
dept_id int constraint fk_dept_id_heihei foreign key references dept(dept_id)
--在emp表中构造一个名字叫做dept_id的属性(列)
--名字叫做fk_dept_id_heihei(constraint fk_emp_id_heihei)的外键(foreign key)
--来自dept(dept_id)(references dept(dept_id))
)
insert into emp values (1,'张三','男',1);
--insert into emp values (2,'李四','女',3);error 因为在dept表中没有dept_id为3的主键
insert into emp(emp_id,emp_name,emp_sex,dept_id) values (2,'李四','女',2);
insert into emp(emp_id,emp_name,emp_sex) values (3,'王五','女');--外键可以为空
3.检查约束(check)
保证事物属性的取值在合法范围之内
实例演示:
create table student1
(
stu_id int primary key,
stu_name nvarchar(10),
stu_age int check (stu_age>=18 and stu_age<=30)
)
insert into student1 values (1,'张三',20);
--insert into student1 values (2,'李四',17); error 因为17<18
insert into student1(stu_id,stu_name) values (3,'王五');--可以为空
4.默认约束(default)
解释:保证事物的属性一定会有一个值
实例演示:
create table student2
(
stu_id int primary key,
stu_name nvarchar(10),
stu_sex nchar(1) default ('男') --()可以省 在数据库中字符串是必须用''括起来的
)
insert into student2 values (1,'张三','男');
insert into student2 values (2,'李四','女');
insert into student2(stu_id,stu_name) values (3,'王五');--不写默认为男
5.非空约束(not null)
解释:不允许为空
实例演示:
create table student3
(
stu_id int primary key,
stu_name nvarchar(10) not null,
stu_sex nchar(1)
)
insert into student3 values (1,'张三','男');
--insert into student3(stu_id,stu_sex) values (2,'女');error 因为姓名不允许为空
insert into student3(stu_id,stu_name) values (2,'李四');
6.唯一约束(unique)
解释:保证了事物属性的取值不允许重复,但允许其中有一列且只能有一列为空,unique和not null约束可以组合使用
实例演示:
create table student4
(
stu_id int primary key,
stu_name nvarchar(10) unique,
stu_sex nchar(1)
)
insert into student4 values (1,'张三','男');
--insert into student4 values (2,'张三','女');error 因为张三已经存在了
insert into student4(stu_id,stu_sex) values (2,'女');
--insert into student4(stu_id,stu_sex) values (3,'女');error 因为已经有一行为空了