SQL Server数据库中的约束

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 因为已经有一行为空了

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值