在 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 个。