[MS SQL]外键约束
来源:互联网 发布:dll文件恢复软件 编辑:程序博客网 时间:2024/05/22 09:30
如果表A的主关键字是表B中的字段,则该字段称为表B的外键,表A称为主表,表B称为从表。外键是用来实现参照完整性的,不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。这里以MySQL为例,总结一下3种外键约束方式的区别和联系。
这里以用户表和用户组表为例,这是一个典型的多对一关系,多个用户对应于一个用户组。
首先创建用户组表:
Sql代码 收藏代码
create table t_group (
id int not null,
name varchar(30),
primary key (id)
);
并插入两条记录:
Sql代码 收藏代码
insert into t_group values (1, 'Group1');
insert into t_group values (2, 'Group2');
下面创建用户表,分别以不同的约束方式创建外键引用关系:
1、级联(cascade)方式
Sql代码 收藏代码
create table t_user (
id int not null,
name varchar(30),
groupid int,
primary key (id),
foreign key (groupid) references t_group(id) on delete cascade on update cascade
);
参照完整性测试
Sql代码 收藏代码
insert into t_user values (1, 'qianxin', 1); --可以插入
insert into t_user values (2, 'yiyu', 2); --可以插入
insert into t_user values (3, 'dai', 3); --错误,无法插入,用户组3不存在,与参照完整性约束不符
约束方式测试
Sql代码 收藏代码
insert into t_user values (1, 'qianxin', 1);
insert into t_user values (2, 'yiyu', 2);
insert into t_user values (3, 'dai', 2);
delete from t_group where id=2; --导致t_user中的2、3记录级联删除
update t_group set id=2 where id=1; --导致t_user中的1记录的groupid级联修改为2
2、置空(set null)方式
Sql代码 收藏代码
置空方式
create table t_user (
id int not null,
name varchar(30),
groupid int,
primary key (id),
foreign key (groupid) references t_group(id) on delete set null on update set null
);
参照完整性测试
insert into t_user values (1, 'qianxin', 1); --可以插入
insert into t_user values (2, 'yiyu', 2); --可以插入
insert into t_user values (3, 'dai', 3); --错误,无法插入,用户组3不存在,与参照完整性约束不符
约束方式测试
insert into t_user values (1, 'qianxin', 1);
insert into t_user values (2, 'yiyu', 2);
insert into t_user values (3, 'dai', 2);
delete from t_group where id=2; --导致t_user中的2、3记录的groupid被设置为NULL
update t_group set id=2 where id=1; --导致t_user中的1记录的groupid被设置为NULL
3、禁止(no action / restrict)方式
Sql代码 收藏代码
禁止方式
create table t_user (
id int not null,
name varchar(30),
groupid int,
primary key (id),
foreign key (groupid) references t_group(id) on delete no action on update no action
);
参照完整性测试
insert into t_user values (1, 'qianxin', 1); --可以插入
insert into t_user values (2, 'yiyu', 2); --可以插入
insert into t_user values (3, 'dai', 3); --错误,无法插入,用户组3不存在,与参照完整性约束不符
约束方式测试
insert into t_user values (1, 'qianxin', 1);
insert into t_user values (2, 'yiyu', 2);
insert into t_user values (3, 'dai', 2);
delete from t_group where id=2; --错误,从表中有相关引用,因此主表中无法删除
update t_group set id=2 where id=1; --错误,从表中有相关引用,因此主表中无法修改
转自:http://qianzui.iteye.com/blog/552878
这里以用户表和用户组表为例,这是一个典型的多对一关系,多个用户对应于一个用户组。
首先创建用户组表:
Sql代码 收藏代码
create table t_group (
id int not null,
name varchar(30),
primary key (id)
);
并插入两条记录:
Sql代码 收藏代码
insert into t_group values (1, 'Group1');
insert into t_group values (2, 'Group2');
下面创建用户表,分别以不同的约束方式创建外键引用关系:
1、级联(cascade)方式
Sql代码 收藏代码
create table t_user (
id int not null,
name varchar(30),
groupid int,
primary key (id),
foreign key (groupid) references t_group(id) on delete cascade on update cascade
);
参照完整性测试
Sql代码 收藏代码
insert into t_user values (1, 'qianxin', 1); --可以插入
insert into t_user values (2, 'yiyu', 2); --可以插入
insert into t_user values (3, 'dai', 3); --错误,无法插入,用户组3不存在,与参照完整性约束不符
约束方式测试
Sql代码 收藏代码
insert into t_user values (1, 'qianxin', 1);
insert into t_user values (2, 'yiyu', 2);
insert into t_user values (3, 'dai', 2);
delete from t_group where id=2; --导致t_user中的2、3记录级联删除
update t_group set id=2 where id=1; --导致t_user中的1记录的groupid级联修改为2
2、置空(set null)方式
Sql代码 收藏代码
置空方式
create table t_user (
id int not null,
name varchar(30),
groupid int,
primary key (id),
foreign key (groupid) references t_group(id) on delete set null on update set null
);
参照完整性测试
insert into t_user values (1, 'qianxin', 1); --可以插入
insert into t_user values (2, 'yiyu', 2); --可以插入
insert into t_user values (3, 'dai', 3); --错误,无法插入,用户组3不存在,与参照完整性约束不符
约束方式测试
insert into t_user values (1, 'qianxin', 1);
insert into t_user values (2, 'yiyu', 2);
insert into t_user values (3, 'dai', 2);
delete from t_group where id=2; --导致t_user中的2、3记录的groupid被设置为NULL
update t_group set id=2 where id=1; --导致t_user中的1记录的groupid被设置为NULL
3、禁止(no action / restrict)方式
Sql代码 收藏代码
禁止方式
create table t_user (
id int not null,
name varchar(30),
groupid int,
primary key (id),
foreign key (groupid) references t_group(id) on delete no action on update no action
);
参照完整性测试
insert into t_user values (1, 'qianxin', 1); --可以插入
insert into t_user values (2, 'yiyu', 2); --可以插入
insert into t_user values (3, 'dai', 3); --错误,无法插入,用户组3不存在,与参照完整性约束不符
约束方式测试
insert into t_user values (1, 'qianxin', 1);
insert into t_user values (2, 'yiyu', 2);
insert into t_user values (3, 'dai', 2);
delete from t_group where id=2; --错误,从表中有相关引用,因此主表中无法删除
update t_group set id=2 where id=1; --错误,从表中有相关引用,因此主表中无法修改
转自:http://qianzui.iteye.com/blog/552878
1 0
- [MS SQL]外键约束
- sql 外键约束
- sql 外键约束
- SQL 外键约束
- sql 外键约束
- SQL - 外键约束
- SQL约束(主键约束 primary key、外键约束 foreign key、唯一约束unique 、CHECK约束)
- SQL 外键约束理解
- SQL删除外键约束
- SQL Server 外键约束
- Sql 多重外键约束
- My SQL外键约束
- sql语句,外键约束
- 20171012 SQL外键约束
- MS SQL入门基础:创建和使用约束
- 关于PowerDesigner15不能从PDM图生成MS SQL2005/2008外键约束的问题
- 关于PowerDesigner15不能从PDM图生成MS SQL2005/2008外键约束的问题
- 关于PowerDesigner15不能从PDM图生成MS SQL2005/2008外键约束的问题
- 从一家电子商务网站学到的经验教训
- 跨站请求伪造CSRF防护方法
- @Repository、@Service、@Controller 和 @Component
- Cover Flow编程1118
- Tsinghua MOOC 范围查询(Range)
- [MS SQL]外键约束
- StringBuffer(可变字符串)和StringBuilder
- C# Windows Schedule task之获取task下次运行时间
- PHP各个版本区别
- JAVA设计模式之 命令模式【Command Pattern】
- AD 用户属性userAccountControl的详细解释
- Linux操作系统文件系统基础知识详解
- eclipse中Android模拟器常见的问题解决方法汇总
- win7+ubuntu 双系统制作教程