gpt4 book ai didi

Django - 使用 bulk_create 复制和插入查询集克隆

转载 作者:行者123 更新时间:2023-12-03 21:28:46 24 4
gpt4 key购买 nike

我的目标是创建一个查询集的克隆,然后将其插入到数据库中。
遵循 this post 的建议,我有以下代码:

qs_new = copy.copy(qs)
MyModel.objects.bulk_create(qs_new)

但是,使用此代码我遇到了 duplicate primary key错误。至于现在,我只能想出以下解决方法:
qs_new = copy.copy(qs)
for x in qs_new:
x.id = None
MyModel.objects.bulk_create(qs_new)

问题 :我可以在不经过循环的情况下实现这个代码片段吗?

最佳答案

想不出没有循环的方法,只是一个建议:

# add all fields here except 'id'
qs = qs.values('field1', 'field2', 'field3')
new_qs = [MyModel(**i) for i in qs]
MyModel.objects.bulk_create(new_qs)

关于Django - 使用 bulk_create 复制和插入查询集克隆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41723702/

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