Django数据模型on_delete属性值

  1. CASCADE
    • 级联删除。当关联对象被删除时,当前对象也会被删除。
    • 这是Django的默认行为(在需要显式声明on_delete之前的版本中)。
  2. PROTECT
    • 保护模式。当尝试删除关联对象时,如果当前对象存在外键引用,则抛出 ProtectedError 异常,阻止删除。
    • 这有助于防止意外删除有依赖关系的对象。
  3. SET_NULL
    • 设置为空。当关联对象被删除时,将当前对象的外键字段设置为 None(即空值)。
    • 要求外键字段允许为空(即 null=True)。
  4. SET_DEFAULT
    • 设置为默认值。当关联对象被删除时,将当前对象的外键字段设置为一个默认值。
    • 要求外键字段有默认值设置(即 default=...)。
  5. SET(...)
    • 自定义设置。允许指定一个值或可调用对象,当关联对象被删除时,将当前对象的外键字段设置为该值或可调用对象的返回值。
    • 如果指定的是可调用对象,它应该在删除发生时被调用,并返回一个适当的值。
  6. DO_NOTHING
    • 不采取任何操作。当关联对象被删除时,Django不会对当前对象的外键字段进行任何操作。
    • 这可能导致数据库完整性错误,如果数据库层面没有相应的外键约束来防止孤立记录的话。
相关推荐
小兔薯了5 小时前
7. LNMP-wordpress
android·运维·服务器·数据库·nginx·php
瑞思蕊萌5 小时前
redis实战篇--完结篇
数据库·redis·缓存
云边有个稻草人5 小时前
金仓数据库:医疗信创国产化转型的核心支撑与实践标杆
数据库·国产数据库·金仓数据库·kes
你好~每一天5 小时前
未来3年,最值得拿下的5个AI证书!
数据结构·人工智能·算法·sqlite·hbase·散列表·模拟退火算法
小码哥0686 小时前
【附源码】货运搬家系统前端开发:Vue.js与高德地图集成指南
数据库·物流管理·货运系统·搬家系统
b***59436 小时前
MySQL数据库(SQL分类)
数据库·sql·mysql
2***63556 小时前
MS SQL Server 实战 统计与汇总重复记录
数据库·oracle
r***86986 小时前
MySQL 8.0安装
数据库·mysql·adb
g***72706 小时前
使用Dify访问数据库(mysql)
数据库·mysql
i***27956 小时前
MySQL 常用 SQL 语句大全
数据库·sql·mysql