SQL学习笔记(4)之外键

外键:

//建立外键

CREATE TABLE TB_NAME(

ID INT,

NAME VARCHAR(20) ,

TEACHER_ID INT,

CONSTRAINT 外键名 FOREIGN KEY (子表字段名) REFERENCES 主表名(主表对应字段名)

);


//删除外键

ALTER TABLE TB_NAME DROP FOREIGN KEY 外键名;


//数据级联:删除(更新)主表数据时,同步删除(更新)字表数据

CONSTRAINT 外键名 FOREIGN KEY (子表字段名) REFERENCES 主表名(主表对应字段名) ON DELETE CASCADE 

ON UPDATE CASCADE;


ALTER TABLE TB_NAME ADD CONSIRAINT 外键名 FOREIGN KEY (子表字段名)

 REFERENCES 主表名(主表对应字段名) ON DELETE CASCADE ON UPDATE CASCADE;


(1)建立外键时,会自动为该字段建立索引;若该字段之前有索引,则不会再为其建立索引。

(2)删除外键后,该字段的索引仍然存在;外键存在时,不能直接删除该字段索引;

(3)建表后,想将普通外键改为级联外键,需要先drop原来外键;

(4)子表外键的字段必须在主表对应字段范围内;

(5)当主表数据被子表引用时,主表不允许删除,子表对应数据删除后才能删除主表,

         但是,当是级联外键时,主表数据允许删除,同时子表对应的数据也被删除;

(6)子表参照的必须是主键列(一表只能有一主键)或唯一列,同一表可以有多个外键。





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值