无法创建唯一索引“ credits_credit_pkey”

时间:2019-07-26 15:55:29

标签: django postgresql django-models

最初,我有一个Credit模型。但是在添加具有相似功能的HypothecAutoCredit模型之后,我意识到我需要制作一个基础模型并从中继承。

当我尝试移民时,我收到一个问题:

You are trying to add a non-nullable field 'abstractbaseproduct_ptr' to `credit` without a default; we can't do that (the database needs something to populate existing rows).
Please select a fix:
 1) Provide a one-off default now (will be set on all existing rows)
 2) Quit, and let me add a default in models.py

*我输入了1; 1.然后我得到一个问题:

  

目前尚不清楚“ abstractbaseproduct_ptr”字段是什么?

然后我得到了

  

您正在尝试将不可以为null的字段abstractbaseaction_ptr添加到creditaction中,而没有默认值;我们无法做到这一点(数据库需要一些东西来填充现有行)。

再次介绍1; 1。

当我尝试迁移时,我会得到

  

django.db.utils.IntegrityError:无法创建唯一索引“ credits_credit_pkey”   详细信息:键(abstractbaseproduct_ptr_id)=(1)已重复。

仅在Credit模型中出现了这样的问题。显然是因为有already data in this table ...

我该如何解决?

class AbstractBaseProduct(models.Model):
    bank = models.ForeignKey('banks.Bank', verbose_name=_('bank'))
    #other fields


class AbstractBaseAction(models.Model):
    name = models.CharField(_('name'), max_length=255)
    short_description = models.CharField(_('short description'), max_length=255)
    full_description = models.TextField(_('full description'), blank=True, null=True)


class Credit(AbstractBaseProduct):
    class Meta:
        verbose_name = _('credit')
        verbose_name_plural = _('Credits')


class CreditAction(AbstractBaseAction):
    credit = models.ForeignKey(Credit, verbose_name=_('credit'))

迁移

migrations.AddField(
            model_name='credit',
            name='abstractbaseproduct_ptr',
            field=models.OneToOneField(auto_created=True, default=1, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='credits.AbstractBaseProduct'),
            preserve_default=False,
        ),
migrations.AddField(
            model_name='creditaction',
            name='abstractbaseaction_ptr',
            field=models.OneToOneField(auto_created=True, default=1, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='credits.AbstractBaseAction'),
            preserve_default=False,
        ),

1 个答案:

答案 0 :(得分:1)

您已经为模型AbstractBaseProduct命名,但是尚未将abstract = True添加到模型的Meta类中,因此Django认为您希望多表继承而不是抽象基类。

有关更多信息,请参见model inheritance上的文档。