继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

SQL外键约束的含义及创建

SELECT_NULL
关注TA
已关注
手记 10
粉丝 15
获赞 350

建立外键约束可以对sql语句的增删改有约束作用。
外键取值规则:空值或参照的主键值。
(1)插入非空值时,如果主键表中没有这个值,则不能插入。
(2)更新时,不能改为主键表中没有的值。
(3)删除主键表记录时,你可以在建外键时选定外键记录一起级联删除还是拒绝删除。
(4)更新主键记录时,同样有级联更新和拒绝执行的选择。


举例如下:
创建表并插入语句

 CREATE TABLE t_group(
    id INT PRIMARY KEY,
    NAME VARCHAR(30)
)

INSERT INTO t_group VALUES(1,'group1');
INSERT INTO t_group VALUES(2,'group2');

CREATE TABLE t_user(
    id INT PRIMARY KEY,
    NAME VARCHAR(30),
    groupid INT FOREIGN KEY REFERENCES t_group(id)
)

INSERT INTO t_user VALUES(1,'user1',1);
INSERT INTO t_user VALUES(2,'user2',2);

其中,t_user是主表,id列是主键,groupid是在表t_group(id)的外键

INSERT INTO t_user VALUES(3,'user3',3);

以上语句因为插入groupid=3,违反外键约束。
插入非空值时,如果主键表中没有这个值,则不能插入。

DELETE FROM t_group WHERE id=2

图片描述

UPDATE t_group SET id=3 WHERE id=1

图片描述
如果需要修改外键约束,比如,要在外键上允许级联修改,但限制删除,则执行下面语句。

ALTER TABLE t_user DROP CONSTRAINT FK_T_USER_GROUPID

ALTER TABLE t_user ADD CONSTRAINT FK_T_USER_GROUPID FOREIGN KEY(GroupID) 
REFERENCES T_GROUP(ID) ON UPDATE CASCADE ON DELETE no action  

打开App,阅读手记
3人推荐
发表评论
随时随地看视频慕课网APP