SQL Server中的约束

目录

1.主键约束(primary key)

2.外键约束(foreign key)

3.检查约束(check)

4.默认约束(default)

5.非空约束(not null)

6.唯一约束(unique)


1.主键约束(primary key)

解释:不允许重复元素,并且不能为空,避免了数据的沉余

实例演示:

create table dept
(
	dept_id int constraint pk_dept_id_haha primary key,
	--在dept表中构造一个名字叫做dept_id的属性(列)
	--名字叫做pk_dept_id_haha(constraint pk_dept_id_haha)的主键(primary key)	
	/*
	简写:
	dept_id int primary key,
	--在dept表中,构造一个名字叫做dept_id的属性(列),
	--并且把它设为主键(primary key)
	*/
	dept_name nvarchar(10),
	--在dept表中,构造一个名字叫做dept_name的属性(列),
	--最多可以放10个字符(nvarchar(10))
	dept_address nvarchar(30)
)
insert into dept values (1,'研发部','北京');
--insert into dept values (1,'市场部','北京'); error 因为主键不允许重复
--insert into dept(dept_name,dept_address) values ('市场部','北京');error 因为主键不允许为空
insert into dept(dept_id,dept_name,dept_address) values (2,'市场部','北京');

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)

解释:保证了事物属性的取值不允许重复,但允许其中有一列且只能有一列为空,uniqe和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 因为已经有一行为空了

猜你喜欢

转载自blog.csdn.net/tswc_byy/article/details/81773246