gpt4 book ai didi

Django - 如何将列的所有值更改为空值?

转载 作者:行者123 更新时间:2023-12-05 02:18:40 26 4
gpt4 key购买 nike

我有一个问题,我对我的模型做了一些更改,因为我有一个必须更改为 ForeignKey

的 Integer 字段

为了避免错误,我将值 1 分配给 derived_to 字段中的所有对象。

我现在想将此列中的所有行标记为空。我该怎么做?这是我最近的两次迁移

class Migration(migrations.Migration):

dependencies = [
('work_order', '0026_auto_20170603_1517'),
]

operations = [
migrations.AlterModelOptions(
name='workorder',
options={'verbose_name': 'work order', 'verbose_name_plural': 'work orders'},
),
migrations.AlterField(
model_name='workorder',
name='derived_to',
field=models.ForeignKey(default=1, on_delete=django.db.models.deletion.CASCADE, to='store.OutsourceOption', verbose_name='outsource'),
preserve_default=False,
),
]

最后一个

class Migration(migrations.Migration):

dependencies = [
('work_order', '0027_auto_20170605_0836'),
]

operations = [
migrations.AlterField(
model_name='workorder',
name='derived_to',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='store.OutsourceOption', verbose_name='outsource'),
),
]

这就是我需要进行新迁移以将 null 分配给列 derived_to 中 work_order 中的所有对象,因为现在所有对象都有 derived_to 指向第一个在 OutsourceOptions 上注册,这是不正确的。

谢谢,抱歉我的英语不好。

最佳答案

如果我没理解错的话,您想将所有现有的 derived_to 值设置为 null?你可以用 RunPython 做到这一点

Runs custom Python code in a historical context. code (and reverse_code if supplied) should be callable objects that accept two arguments;

def forwards_func(apps, schema_editor):

Workorder = apps.get_model('appname','Workorder')
Workorder.objects.update(derived_to=None)

像这样将其添加到迁移中:

operations = [
migrations.AlterField(
model_name='workorder',
name='derived_to',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='store.OutsourceOption', verbose_name='outsource'),
),
migrations.RunPython(forwards_func),
]

关于Django - 如何将列的所有值更改为空值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44369507/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com