手记

SQL外键约束的含义及创建

建立外键约束可以对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  

3人推荐
随时随地看视频
慕课网APP