python3.X版本中,app models下创建表注意事项

在数据库表设计中,正确设置一对多关系的ForeignKey非常重要。若不设置on_delete选项,将导致创建表时出现错误。on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT和SET()五种选项,其中CASCADE用于级联删除,PROTECT阻止删除,SET_NULL设为NULL,SET_DEFAULT设为默认值,SET()调用外部值。了解这些选项有助于避免完整性错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当创建的两个表为一对多关系时,需要在Foreignkey中设置on_delete=

190155_BL85_3859736.png

如果不设置,创建时会报如下错误。

190419_PJge_3859736.png

on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值
CASCADE:表示级联删除。
PROTECT:报完整性错误。
SET_NULL:把外键设置为null,前提是允许为null。
SET_DEFAULT:把设置为外键的默认值。
SET():此值设置,会调用外面的值,可以是一个函数。
一般情况下使用CASCADE就可以了。

转载于:https://my.oschina.net/u/3859736/blog/1823177

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值