Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/56.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql on_delete=models.SET_ForeignKey字段中的NULL选项无效_Mysql_Django - Fatal编程技术网

Mysql on_delete=models.SET_ForeignKey字段中的NULL选项无效

Mysql on_delete=models.SET_ForeignKey字段中的NULL选项无效,mysql,django,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 删除项的实例时

我有两个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
删除
项的实例时
会得到一个整数错误:

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 = models.ForeignKey('Item', blank=True, null=True)

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

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

我正在使用Django 1.5


有人能帮忙吗?

你有外宾互相指点,这是个好做法吗?@catherine:我知道这不是个好做法。我应该使用另一个表来显示“特色项目”字段,但是如果这个on\u delete功能正常,我会节省很多时间。@catherine:这个链接似乎没有帮助是的,我只是想让你看看你所做的事情的风险。
featured_item = models.ForeignKey('Item', blank=True, null=True, on_delete=models.SET_NULL)