小编Hol*_*lly的帖子

使用字符串替换的Django批量更新

我正在尝试更新和修改字符串字段Django的ORM.执行此操作的等效SQL是:

UPDATE example_table SET string_field = REPLACE(string_field, 'old text', 'new text');
Run Code Online (Sandbox Code Playgroud)

随着该查询,我希望old textold text more text对被替换new text,并new text more text分别在所有条目string_field列.

批量更新()似乎很有希望,但不允许我只修改字段的一部分,而F()表达式只实现数字更改,而不是字符串替换.我还看了使用原始查询来运行上面的SQL,但这似乎是一个横向黑客(特别是因为F()存在以对数字执行相同的功能),我无法让它们实际执行.

我最终得到了这个,但是当我知道有一行SQL语句来执行所有额外的查询时,这似乎是一种耻辱.

for entry in ExampleModel.objects.all():
    entry.string_field = entry.string_field.replace('old text', 'new text', 1)
    entry.save()
Run Code Online (Sandbox Code Playgroud)

这个功能在Django的ORM中不存在用于字符串吗?我在文档中忽略了什么吗?

相关的SO问题:

python django django-orm

16
推荐指数
2
解决办法
5443
查看次数

标签 统计

django ×1

django-orm ×1

python ×1