前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >django Foreignkey 之 on_delete

django Foreignkey 之 on_delete

作者头像
卓越笔记
发布2023-02-18 10:27:43
2460
发布2023-02-18 10:27:43
举报
文章被收录于专栏:卓越笔记

on_delete 指的是通过 ForeignKey 连接起来的当前对象被删除后,外键字段进行的操作。

# models.py

代码语言:javascript
复制
from django.db import models


class Article(models.Model):
    """
    主题表/文章表
    """
    title = models.CharField(max_length=128, verbose_name="标题")
    content = RichTextUploadingField(verbose_name="内容", config_name='awesome_ckeditor')
    node = models.ForeignKey(Node, on_delete=models.DO_NOTHING, verbose_name="所属节点")  # models.DO_NOTHING, Article 删除 Node 啥也不干

# D:\Program Files\Python36\Lib\site-packages\django\db\models\deletion.py

代码语言:javascript
复制
def CASCADE(collector, field, sub_objs, using):
    """
    当前对象删除后,一并删除该对象下的外键信息
    :param collector:
    :param field:
    :param sub_objs:
    :param using:
    :return:
    """
    collector.collect(sub_objs, source=field.remote_field.model,
                      source_attr=field.name, nullable=field.null)
    if field.null and not connections[using].features.can_defer_constraint_checks:
        collector.add_field_update(field, None, sub_objs)


def PROTECT(collector, field, sub_objs, using):
    """
    删除时会引起 ProtectedError,不删除关联表的内容
    :param collector:
    :param field:
    :param sub_objs:
    :param using:
    :return:
    """
    raise ProtectedError(
        "Cannot delete some instances of model '%s' because they are "
        "referenced through a protected foreign key: '%s.%s'" % (
            field.remote_field.model.__name__, sub_objs[0].__class__.__name__, field.name
        ),
        sub_objs
    )


def SET(value):
    """
    SET(), 此时需要指定 set 的值, 括号里可以是函数,也可以为自己定义的东西;
    :param value:
    :return:
    """
    if callable(value):
        def set_on_delete(collector, field, sub_objs, using):
            collector.add_field_update(field, value(), sub_objs)
    else:
        def set_on_delete(collector, field, sub_objs, using):
            collector.add_field_update(field, value, sub_objs)
    set_on_delete.deconstruct = lambda: ('django.db.models.SET', (value,), {})
    return set_on_delete


def SET_NULL(collector, field, sub_objs, using):
    """
    只有当当前字段设置 null 设置为 True 才有效,此情况会将 ForeignKey 字段设置为 null
    :param collector:
    :param field:
    :param sub_objs:
    :param using:
    :return:
    """
    collector.add_field_update(field, None, sub_objs)


def SET_DEFAULT(collector, field, sub_objs, using):
    """
    当前字段设置了default 才有效,此情况会将 ForeignKey 字段设置为 default 值
    :param collector:
    :param field:
    :param sub_objs:
    :param using:
    :return:
    """
    collector.add_field_update(field, field.get_default(), sub_objs)


def DO_NOTHING(collector, field, sub_objs, using):
    """
    什么也不做
    :param collector:
    :param field:
    :param sub_objs:
    :param using:
    :return:
    """
    pass
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-8-29 1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档