我正在使用 Postgress 数据库的生产系统上运行迁移,当我运行它时,出现以下错误:
django.db.utils.ProgrammingError:不允许表“website_experience”有多个主键
但在我的开发 SQL 数据库上运行良好。这是我正在使用的模型:
class Experience (models.Model):
title = models.CharField(max_length = 60)
company = models.CharField(max_length = 60)
city = models.CharField(max_length = 60)
start_date = models.DateField(blank=False, default=datetime.now)
end_date = models.DateField(blank=True, null=True)
description = models.CharField(max_length = 1000)
creative_user = ForeignKey(CreativeUserProfile, models.CASCADE)
Run Code Online (Sandbox Code Playgroud)
最初,字段creative_user(这是我的扩展用户模型)是一个主键,但将其更改为外键以表达具有许多工作经验的一个CreativeUser之间的一对多关系。
这是更改foreignkey之前和之后的迁移
class Migration(migrations.Migration):
dependencies = [
('website', '0003_auto_20170510_1436'),
]
operations = [
migrations.CreateModel(
name='Experience',
fields=[
('title', models.CharField(max_length=60)),
('company', models.CharField(max_length=60)),
('city', models.CharField(max_length=60)),
('startDate', models.DateField()),
('endDate', models.DateField(blank=True, null=True)),
('creative_user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, primary_key=True, serialize=False, to='website.CreativeUserProfile')),
],
),
]
Run Code Online (Sandbox Code Playgroud)
这表达了体验模型的创建,并且creative_user是模型上的主键。然后将其设为外键后,迁移如下所示:
class Migration(migrations.Migration): …Run Code Online (Sandbox Code Playgroud)