最初,我有一个Credit
模型。但是在添加具有相似功能的Hypothec
和AutoCredit
模型之后,我意识到我需要制作一个基础模型并从中继承。
当我尝试移民时,我收到一个问题:
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,
),
答案 0 :(得分:1)
您已经为模型AbstractBaseProduct
命名,但是尚未将abstract = True
添加到模型的Meta
类中,因此Django认为您希望多表继承而不是抽象基类。
有关更多信息,请参见model inheritance上的文档。