CASCADE:- 级联删除。当关联对象被删除时,当前对象也会被删除。
- 这是Django的默认行为(在需要显式声明
on_delete之前的版本中)。
PROTECT:- 保护模式。当尝试删除关联对象时,如果当前对象存在外键引用,则抛出
ProtectedError异常,阻止删除。 - 这有助于防止意外删除有依赖关系的对象。
- 保护模式。当尝试删除关联对象时,如果当前对象存在外键引用,则抛出
SET_NULL:- 设置为空。当关联对象被删除时,将当前对象的外键字段设置为
None(即空值)。 - 要求外键字段允许为空(即
null=True)。
- 设置为空。当关联对象被删除时,将当前对象的外键字段设置为
SET_DEFAULT:- 设置为默认值。当关联对象被删除时,将当前对象的外键字段设置为一个默认值。
- 要求外键字段有默认值设置(即
default=...)。
SET(...):- 自定义设置。允许指定一个值或可调用对象,当关联对象被删除时,将当前对象的外键字段设置为该值或可调用对象的返回值。
- 如果指定的是可调用对象,它应该在删除发生时被调用,并返回一个适当的值。
DO_NOTHING:- 不采取任何操作。当关联对象被删除时,Django不会对当前对象的外键字段进行任何操作。
- 这可能导致数据库完整性错误,如果数据库层面没有相应的外键约束来防止孤立记录的话。
Django数据模型on_delete属性值
啧不应该啊2024-11-05 0:36
相关推荐
祖传F8715 小时前
SQL DATE()函数会抹去时间戳untE EADO15 小时前
在 MySQL 中使用 `REPLACE` 函数Absurd58715 小时前
Redis如何限制列表最大长度_利用LTRIM指令截断List保留最新记录2401_8822737215 小时前
SQL函数面试题解析_函数性能与设计考点l1t15 小时前
DeepSeek总结的DuckDB internals 的 设计与实现 (DiDi)a95114164215 小时前
mysql查询分析中如何快速识别全表扫描_通过EXPLAIN中的type列检查coNh OOSI15 小时前
Redis——Windows安装weixin_4249993615 小时前
mysql如何防止索引被错误使用_mysql查询计划强制约束Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.15 小时前
Redis主从复制配置全攻略m0_6138562916 小时前
Golang怎么实现测试跳过条件_Golang如何根据环境或条件跳过不适用的测试用例【操作】