ForeignKey字段中的on_delete = models.SET_NULL选项无效

时间:2013-03-20 08:19:08

标签: mysql django

我有两个Django模型,外键引用另一个:

class Style(models.Model):
    featured_item = models.ForeignKey('Item', blank=True, null=True)
    # more fields

class Item(models.Model):
    style = models.ForeignKey(Style, blank=True, null=True) 
    # more fields

删除Item的实例时,我收到了一个IntegrityError:

In [4]: cursor.execute("DELETE FROM myapp_item WHERE n = 0)

IntegrityError: (1451, 'Cannot delete or update a parent row: a foreign key constraint fails (`mydb`.`myapp_style`, CONSTRAINT `featured_item_id_refs_id_578e3e581685bdae` FOREIGN KEY (`featured_item_id`) REFERENCES `myapp_item` (`id`))')

所以我将on_delete=models.SET_NULL选项添加到featured_item模型的Style外键字段中,即已替换

featured_item = models.ForeignKey('Item', blank=True, null=True)

通过

featured_item = models.ForeignKey('Item', blank=True, null=True, on_delete=models.SET_NULL)

使用South。迁移我的数据库(已有数据)。

但是在删除Item实例时仍然会出现外键约束错误。

我正在使用Django 1.5。

有人可以帮忙吗?

0 个答案:

没有答案