- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这里有一些模型:
class UserProfile(models.Model):
name = models.CharField(max_length=30)
email = models.EmailField(unique=True, db_index=True)
birthday = models.DateField()
class Photo(models.Model):
user = models.ForeignKey(UserProfile)
description = models.TextField(blank=True)
photo = models.ImageField(upload_to='img/photo')
假设用户有 10 张照片(Photo
模型的 10 个对象)。当用户删除自己时,所有这 10 个 Photo
数据库行都会自动删除吗? (我读过文档,但英语不是我的母语,所以我不了解 on_delete
属性的所有内容。)
最佳答案
我将介绍适用于这种情况的 on_delete
的值。正如它在文档中指出的那样,这些都在 models
模块中,因此您可以将其用作 models.ForeignKey(UserProfile, on_delete=models.CASCADE)
等.
无论您是在管理面板中还是直接使用 Model
实例删除对象,这些规则都适用。 (但如果你直接在 SQL 中使用底层数据库,它不会生效。)
CASCADE
:当您删除UserProfile
时,所有相关的Photo
也会被删除。这是默认设置。 (所以在回答你问题的那个方面时,是的,如果你删除你的用户帐户,照片将自动删除。)
PROTECT
:这将阻止您删除具有相关 Photo
的 UserProfile
,引发 django.db .models.ProtectedError
如果你尝试。这个想法是,用户需要取消关联或删除所有照片
,然后才能删除他们的个人资料。
SET_NULL
:当您删除 UserProfile
时,所有关联的 Photo
将仍然存在,但将不再与任何关联用户资料
。这将需要 ForeignKey
定义中的 null=True
。
SET_DEFAULT
:当您删除 UserProfile
时,所有关联的 Photo
都将更改为指向它们的默认 由
(您可以使用它来将“孤立”照片传递给特定用户 - 但这不是这不会很常见,ForeignKey
定义中的 default
属性指定的 UserProfileSET_NULL
或 SET()
会更常见)
SET()
:当你删除UserProfile
时,Photo
的目标ForeignKey
将被设置为传递给 SET
函数的值,或者它返回的值(如果它是可调用的)。 (抱歉,我没有解释清楚,但是 docs 有一个解释得更好的例子。)
DO_NOTHING
:当您删除 UserProfile
时,所有相关的 Photo
都将保持不变,因此引用已损坏,除非你已经使用了一些其他的 SQL 来处理它。
(此外,on_delete
不是方法。它是 ForeignKey
字段的属性。)
关于Django 模型 ForeignKey on_delete 属性 : full meaning?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8543877/
我一直在使用 -Wd Python 的论据,并发现我需要进行大量更改以准备升级到 Django 2.0 python -Wd manage.py runserver 最主要的是 on_delete 是
我正在为 Django 应用程序编写测试。 目前,为了测试级联删除,我创建了实例,删除了父项并断言子项也被删除了。 是否有更好的方法来执行此操作,例如使用 _meta.get_field 检索传递给模
我正在尝试在模型中使用on_delete,但我的IDE要求我提供:收集器,字段,sub_objs,使用(即..., on_delete=models.PROTECT(collector, fields
django 上的 ForeignKey 具有属性 on_delete指定删除引用的对象时的行为。有什么办法可以得到类似的东西 ManyToManyField ? 假设我有以下模型 class Hou
我正在尝试使用 django 运行一些 python 代码,但它返回“构造函数调用中的参数‘on_delete’没有值”。 from django.db import models from djan
我正在和 Phoenix 一起玩,并建立了 has_many 关联。我通常将 on_delete: :delete_all 作为引用列的选项。但是,如果我改变主意并想稍后更改 nilify_all,有
我正在尝试使用 django 运行一些 python 代码,但它返回“构造函数调用中的参数‘on_delete’没有值”。 from django.db import models from djan
我在两个模型之间建立了多对多关系,User 和 Role,通过中间表 UserRoleThrough 实现,它有两个 ForeignKeyField:一个引用 User,另一个引用 Role。据我从文
我在 django 中有一个模型,它具有带有用户模型的外键。 class News(models.Model): user = models.ForeignKey(AUTH_USER_MODE
File "C:\Users\sungk\Git\django_website\blog\models.py", line 5, in class Post(models.Model): F
在下面的示例中,您如何以及在哪里设置默认值? author = models.ForeignKey('作者', on_delete=models.SET_DEFAULT) 最佳答案 对于 SET_DE
请让我考虑以下两个模型: class Policy(models.Model): name = models.SlugField(max_length=256, blank = Fal
请让我考虑以下两个模型: class Policy(models.Model): name = models.SlugField(max_length=256, blank = Fal
我目前正在做 Eric Matthes 所著的《Python 速成类(class)》一书中的一些项目。目前,我正在做实验 19.1,我必须使用以前的代码来制作 Django 项目,同时更改他自己的一些
我正在使用 django 1.2.4(通过 shell 使用 import django django.VERSION 确认)并尝试使用 on_delete=models.SET_NULL 在 For
我对 Django 非常熟悉,但我最近注意到存在一个 on_delete=models.CASCADE与模型选项。我已经搜索了相同的文档,但除了以下内容之外我什么也找不到: Changed in Dj
我对Django非常熟悉,但是最近发现模型中存在on_delete=models.CASCADE和on_delete=models.PROTECT选项, on_delete=models.CASCAD
假设我有一个代理用户模型 class UserWithProfile(User): profile_description = models.TextField() class Met
我有一个 Django 1.3 应用程序,我使用 South 0.7.3 进行数据库迁移。我有一个问题 on_delete=models.SET_NULL删除父实体时,规则似乎没有触发,从而使我违反了
我定义了一个 on_delete我的模型中的约束如下: cliente = models.ForeignKey(Cliente,related_name="cliente",on_delete=mod
我是一名优秀的程序员,十分优秀!