5

もう一方を参照する外部キーを持つ 2 つの 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_itemStyle

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を使用しています。

誰でも助けることができますか?

4

0 に答える 0