在 Django 迁移中使用特定日期预填充 DateTimeField
Pre-populate DateTimeField with specific date in django migration
我想创建 DateTimeField 并用特定日期预填充现有对象。
models.py
publish_date = models.DateTimeField(verbose_name=_('publish date'))
我尝试先创建一个可为空的字段,用一些数据填充它,然后从中删除 null=True
:
migrations.py
def set_default_publish_date(apps, schema_editor):
MyModel = apps.get_model('myapp', 'MyModel')
MyModel.objects.all().update(publish_date=datetime.date(day=1, month=1, year=2019))
class Migration(migrations.Migration):
dependencies = [
('myapp', '0005_auto_20200831_1208'),
]
operations = [
migrations.AddField(
model_name='mymodel',
name='publish_date',
field=models.DateTimeField(null=True, verbose_name='publish date'),
preserve_default=False,
),
migrations.RunPython(set_default_publish_date, migrations.RunPython.noop),
migrations.AlterField(
model_name='mymodel',
name='publish_date',
field=models.DateTimeField(verbose_name='publish date'),
preserve_default=False,
),
]
由于 运行 迁移,我得到一个错误:
django.db.utils.OperationalError: cannot ALTER TABLE
"myapp_mymodel" because it has pending trigger events
我该如何解决?
只需将您的迁移分成 2 个或可能的 3 个。您应该能够在一次迁移中执行前 2 个操作,但不能执行第 3 个。
我想创建 DateTimeField 并用特定日期预填充现有对象。
models.py
publish_date = models.DateTimeField(verbose_name=_('publish date'))
我尝试先创建一个可为空的字段,用一些数据填充它,然后从中删除 null=True
:
migrations.py
def set_default_publish_date(apps, schema_editor):
MyModel = apps.get_model('myapp', 'MyModel')
MyModel.objects.all().update(publish_date=datetime.date(day=1, month=1, year=2019))
class Migration(migrations.Migration):
dependencies = [
('myapp', '0005_auto_20200831_1208'),
]
operations = [
migrations.AddField(
model_name='mymodel',
name='publish_date',
field=models.DateTimeField(null=True, verbose_name='publish date'),
preserve_default=False,
),
migrations.RunPython(set_default_publish_date, migrations.RunPython.noop),
migrations.AlterField(
model_name='mymodel',
name='publish_date',
field=models.DateTimeField(verbose_name='publish date'),
preserve_default=False,
),
]
由于 运行 迁移,我得到一个错误:
django.db.utils.OperationalError: cannot ALTER TABLE "myapp_mymodel" because it has pending trigger events
我该如何解决?
只需将您的迁移分成 2 个或可能的 3 个。您应该能够在一次迁移中执行前 2 个操作,但不能执行第 3 个。