CASCADE、PROTECT、SET_NULL是什么属性
时间: 2024-05-27 07:13:40 浏览: 14
CASCADE、PROTECT、SET_NULL是Django中的外键属性。
- CASCADE:当主表中的数据被删除时,与其相关联的外键表中的数据也会被删除。
- PROTECT:当主表中的数据被删除时,如果与其相关联的外键表中还有数据,则会抛出ProtectedError异常,防止误删数据。
- SET_NULL:当主表中的数据被删除时,与其相关联的外键表中的数据会被设置为NULL。这要求外键字段必须允许NULL值,否则会抛出IntegrityError异常。
相关问题
on_delete=models.CASCADE
`on_delete=models.CASCADE` 是 Django 中 ForeignKey 字段的一个参数,用于指定级联删除的行为。具体来说,它表示当关联的主表中某一行被删除时,与之相关的从表中的一行或多行也将被删除。CASCADE 表示级联删除,也就是删除主表中的行时,将同时删除与之相关的从表中的行。除了 CASCADE 外,还有其他可选参数,比如 SET_NULL、SET_DEFAULT、PROTECT 等,它们分别表示在删除主表中某一行时,将与之相关的从表中的行设置为 NULL、设置为默认值、禁止删除等不同的行为。
django外键字段的on_delete属性
在 Django 中,外键字段的 `on_delete` 属性用于指定当关联的对象被删除时的行为。它是必需的,因为它决定了当关联的对象被删除时,包含该外键的对象应该如何处理。
`on_delete` 属性可以设置以下几种选项:
- `models.CASCADE`:级联删除。当关联的对象被删除时,包含该外键的对象也会被删除。
- `models.PROTECT`:保护约束。当关联的对象被删除时,会引发 `ProtectedError` 异常,阻止删除操作。
- `models.SET_NULL`:设置为 NULL。当关联的对象被删除时,外键字段会被设置为 `NULL`(仅适用于可为空的外键字段)。
- `models.SET_DEFAULT`:设置为默认值。当关联的对象被删除时,外键字段会被设置为其默认值(仅适用于有默认值的外键字段)。
- `models.SET()`:设置为指定值。当关联的对象被删除时,外键字段会被设置为指定的值,该值可以是一个对象或一个可调用对象。
- `models.SET_CONSTRAINT`:设置为约束。当关联的对象被删除时,会引发 `django.db.IntegrityError` 异常,阻止删除操作。
- `models.DO_NOTHING`:不采取任何行动。当关联的对象被删除时,什么都不会发生。
下面是一个示例,演示了如何在 Django 模型中使用外键字段和 `on_delete` 属性:
```python
from django.db import models
class Author(models.Model):
name = models.CharField(max_length=100)
class Book(models.Model):
title = models.CharField(max_length=100)
author = models.ForeignKey(Author, on_delete=models.CASCADE)
```
在上述示例中,`Book` 模型包含一个外键字段 `author`,它与 `Author` 模型建立了关联。`on_delete=models.CASCADE` 指定了级联删除的行为,即当关联的 `Author` 对象被删除时,相关的 `Book` 对象也会被删除。
根据需求,你可以选择适当的 `on_delete` 行为来处理外键关联对象的删除操作。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)