12 python与mysql 外键约束 外键级联

保证数据的准确性

外键约束

建立好了关系字段(B表引用A表的主键)之后,为了保证关系字段数据的正确而添加的约束。

create table scores(
id int primary key auto_increment not null,
stuid int,
subid int,
score decimal(5,2), ! 一共5位数,小数部分占2位
foreign key(stuid) references students(id), 
foreign key(subid) references subjects(id)
);

后面两句命令就是 引用外键并且有约束。

此时,如果插入的数据的stuid不存在于学生表的id中,会提示错误!

外键的级联操作

在上面的操作中,我们保证了添加数据的一致性,那么删除数据时呢?如果我们在学生表中删除了一名学生的信息,那么在成绩表中,也应当对应删除这名学生的成绩。

外键的级联操作,做的就是这件事情。
可以在创建表时指定级联操作,也可以在创建表后再修改外键的级联操作。

当然用逻辑删除的话,也可以进行相关的操作。

级联操作的类型有:

  • restrict(限制):默认值,抛异常
  • cascade(级联):如果主表的记录删掉,则从表中相关联的记录都将被删除
  • set null:将外键设置为空
  • no action:什么都不做

这4种操作都不怎么样,所以我们一般做逻辑删除,多加一个isdelete字段来标注 是否被删除。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值