数据库的级联删除

级联删除是指在数据库中删除一个对象时,与该对象有关的其他对象也被自动删除。在 Django 中,级联删除通常通过在模型中定义外键时使用 on_delete 参数来实现。以下是一些常见的 on_delete 选项:

1.models.CASCADE: 当关联的对象被删除时,删除包含外键的对象。这是级联删除的默认选项。

复制代码
class OtherModel(models.Model):
    user = models.ForeignKey(MyUser, on_delete=models.CASCADE)

在这个例子中,如果删除与 OtherModel 关联的 MyUser 对象,相关的 OtherModel 对象也将被删除。

2.多级联删除: 如果你有多个模型之间存在多级关系,级联删除会依次传播。例如,如果有三个模型 A、B、C,A 与 B 有外键关系,B 与 C 有外键关系,如果删除 A,则 B 和 C 中相关的对象也会被删除。

复制代码
class B(models.Model):
    a = models.ForeignKey(A, on_delete=models.CASCADE)

class C(models.Model):
    b = models.ForeignKey(B, on_delete=models.CASCADE)

删除 A 对象时,与 A 关联的 B 对象也将被删除,进而与 B 关联的 C 对象也会被删除。

3.models.PROTECT: 防止删除关联的对象。如果试图删除关联的对象,将引发 ProtectedError 异常。

复制代码
class OtherModel(models.Model):
    user = models.ForeignKey(MyUser, on_delete=models.PROTECT)

如果试图删除与 OtherModel 关联的 MyUser 对象,将引发 ProtectedError 异常,从而防止删除。

4.models.SET_NULL: 将外键设置为 NULL(仅适用于可为 NULL 的外键字段)。

复制代码
class OtherModel(models.Model):
    user = models.ForeignKey(MyUser, on_delete=models.SET_NULL, null=True)

如果删除与 OtherModel 关联的 MyUser 对象,OtherModel 中的 user 外键将被设置为 NULL。

5.models.SET_DEFAULT: 将外键设置为默认值。

复制代码
class OtherModel(models.Model):
    user = models.ForeignKey(MyUser, on_delete=models.SET_DEFAULT, default=default_user_id)

如果删除与 OtherModel 关联的 MyUser 对象,OtherModel 中的 user 外键将被设置为默认值。

models.SET: 将外键设置为指定的值。

复制代码
class OtherModel(models.Model):
    user = models.ForeignKey(MyUser, on_delete=models.SET(set_user_id))

如果删除与 OtherModel 关联的 MyUser 对象,OtherModel 中的 user 外键将被设置为指定的值。

models.SET_NULL 和 models.SET_DEFAULT 的注意事项: 这两个选项只能用于可为 NULL 的外键字段。如果外键字段不可为 NULL,使用这两个选项将会引发 ValueError。

复制代码
class OtherModel(models.Model):
    user = models.ForeignKey(MyUser, on_delete=models.SET_NULL, null=True)  # 可以使用
    user = models.ForeignKey(MyUser, on_delete=models.SET_DEFAULT, default=default_user_id, null=True)  # 可以使用

    user = models.ForeignKey(MyUser, on_delete=models.SET_NULL)  # 会引发 ValueError
    user = models.ForeignKey(MyUser, on_delete=models.SET_DEFAULT, default=default_user_id)  # 会引发 ValueError

6.models.DO_NOTHING: 什么也不做。删除关联的对象后,不对外键进行任何操作。

复制代码
class OtherModel(models.Model):
    user = models.ForeignKey(MyUser, on_delete=models.DO_NOTHING)

使用这个选项时,你需要确保在数据库级别处理外键的完整性。这通常需要你手动管理外键的约束。

相关推荐
5***E6851 小时前
【SQL】写SQL查询时,常用到的日期函数
数据库·sql
遇见火星1 小时前
CentOS7 通过源码安装 Redis
数据库·redis·缓存
Mr.朱鹏1 小时前
RocketMQ安装与部署指南
java·数据库·spring·oracle·maven·rocketmq·seata
Coder-coco1 小时前
个人健康管理|基于springboot+vue+个人健康管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·mysql·论文
K哥11252 小时前
【9天Redis系列】基础+全局命令
数据库·redis·缓存
s***46982 小时前
【玩转全栈】----Django模板语法、请求与响应
数据库·python·django
f***R82 小时前
redis分页查询
数据库·redis·缓存
g***72702 小时前
【mysql】导出导入mysql表结构或者数据
数据库·mysql
煎蛋学姐2 小时前
SSM汽车租赁管理系统mfobv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·汽车·ssm 框架·汽车租赁管理系统
w***37512 小时前
Spring 核心技术解析【纯干货版】- Ⅶ:Spring 切面编程模块 Spring-Instrument 模块精讲
前端·数据库·spring