Django 1.7:Makemigration:不可为空的字段
Django 1.7: Makemigration: non-nullable field
我正在尝试在我的项目中使用 django-orderedmodel (https://github.com/kirelagin/django-orderedmodel)。
运行 makemigrations 不起作用:
You are trying to add a non-nullable field 'order' to slide 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
Select an option:
我想知道我哪里做错了。谢谢
由于 order
字段是唯一的,您需要在多个迁移步骤中添加该字段,替换迁移中的原始 operations
:
- 添加一个可为空的字段,将默认设置为
NULL
。
- 将字段设置为每行中的唯一值。
- 添加一个
NOT NULL
约束。
即像这样:
operations = [
migrations.AddField('myapp.MyModel', 'order', models.PositiveIntegerField(null=True, unique=True)),
migrations.RunPython(set_order),
migrations.AlterField('myapp.MyModel', 'order', models.PositiveIntegerField(blank=True, unique=True)),
]
其中 set_order
是将 order
设置为有效值的函数,例如:
def set_order(apps, schema_editor):
MyModel = apps.get_model('myapp', 'MyModel')
for i, model in enumerate(MyModel.objects.all()):
model.order = i
model.save()
最简单的方法是提供默认值(即 0
),然后替换生成的迁移中的 operations
。
我正在尝试在我的项目中使用 django-orderedmodel (https://github.com/kirelagin/django-orderedmodel)。
运行 makemigrations 不起作用:
You are trying to add a non-nullable field 'order' to slide 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
Select an option:
我想知道我哪里做错了。谢谢
由于 order
字段是唯一的,您需要在多个迁移步骤中添加该字段,替换迁移中的原始 operations
:
- 添加一个可为空的字段,将默认设置为
NULL
。 - 将字段设置为每行中的唯一值。
- 添加一个
NOT NULL
约束。
即像这样:
operations = [
migrations.AddField('myapp.MyModel', 'order', models.PositiveIntegerField(null=True, unique=True)),
migrations.RunPython(set_order),
migrations.AlterField('myapp.MyModel', 'order', models.PositiveIntegerField(blank=True, unique=True)),
]
其中 set_order
是将 order
设置为有效值的函数,例如:
def set_order(apps, schema_editor):
MyModel = apps.get_model('myapp', 'MyModel')
for i, model in enumerate(MyModel.objects.all()):
model.order = i
model.save()
最简单的方法是提供默认值(即 0
),然后替换生成的迁移中的 operations
。