django 中ForeignKey()中的on_delete参数

1.django从1.9开始ForeignKey中的on_delete参数是必须的。

2.案例

代码:

  from django.db import models


class Topic(models.Model):
  """用户学习主题"""
  text = models.CharField(max_length=200)
  data_added = models.DateTimeField(auto_now_add=True)
  
  def __str__(self):
    """返回模型的字符串表示"""
    return self.text
    
class Entry(models.Model):
  """学到的有关某个主题的具体知识"""
  topic = models.ForeignKey(Topic)
  text = models.TextField()
  data_added = models.DateTimeField(auto_now_add=True)
  
  class Meta:
    verbose_name_plural = 'entries'
    
  def __str__(self):
    """返回模型的字符串表示"""

    return self.text[:50] + "..."

结果:


解决方案:

将foreignkey的on_delete属性设置为models.CASCADE,即将上面

topic = models.ForeignKey(Topic)改为topic = models.ForeignKey(Topic,on_delete=models.CASCADE)

Django中,`on_delete`参数用于定义当关联对象被删除时,当前对象的处理方式。这个参数通常在使用外键(ForeignKey)或一对一关系(OneToOneField)时设置。 以下是`on_delete`参数的几种常见选项: 1. **CASCADE**: 级联删除。如果关联的对象被删除,那么引用它的所有对象也会被删除。 ```python models.ForeignKey(OtherModel, on_delete=models.CASCADE) ``` 2. **PROTECT**: 保护模式。如果尝试删除一个被其他对象引用的对象,会抛出一个错误,阻止删除操作。 ```python models.ForeignKey(OtherModel, on_delete=models.PROTECT) ``` 3. **SET_NULL**: 设置为空。如果关联的对象被删除,外键字段会被设置为`NULL`。这要求外键字段允许为空(null=True)。 ```python models.ForeignKey(OtherModel, on_delete=models.SET_NULL, null=True) ``` 4. **SET_DEFAULT**: 设置为默认值。如果关联的对象被删除,外键字段会被设置为默认值。这要求外键字段有一个默认值。 ```python models.ForeignKey(OtherModel, on_delete=models.SET_DEFAULT, default=default_value) ``` 5. **SET()**: 设置为特定值或调用一个函数。如果关联的对象被删除,外键字段会被设置为指定的值或通过调用一个函数来获取值。 ```python models.ForeignKey(OtherModel, on_delete=models.SET(some_value)) # 或者 models.ForeignKey(OtherModel, on_delete=models.SET(get_default_value)) ``` 6. **DO_NOTHING**: 不执行任何操作。如果关联的对象被删除,外键字段保持不变。这可能会导致数据库中的不一致状态,因此使用时需要谨慎。 ```python models.ForeignKey(OtherModel, on_delete=models.DO_NOTHING) ``` 选择合适的`on_delete`策略取决于具体的业务需求和数据完整性要求。例如,如果你希望在删除某个用户时自动删除其相关的订单记录,可以使用`CASCADE`;如果你希望保留订单记录但标记用户已删除,可以使用`SET_NULL`并允许该字段为空。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值