Django:在事务中保存多个ManyToMany字段

6 投票
2 回答
2590 浏览
提问于 2025-04-17 07:28

这是我模型的表示方式:

class B(models.Model):
   """I'm a dummy model, so doesn't pay atention of what I do"""
   name = models.CharField(max_length=250)

class A(models.Model):
   name = models.CharField(max_length=250)
   many_b = models.ManyToManyField(B)

现在,假设我有一个 B 对象的列表,还有一个单独的 A 对象,这个 A 对象会和这些 B 对象相关联。大概是这样的:

a = A.objects.get(id=1)
list_of_b = [B<name='B1'>,B<name='B2'>,B<name='B3'>,]

我现在关联它们的方式是这样的:

for b_object in list_of_b:
   a.many_b.add(b_object)

有没有办法在一个事务中添加所有的 B 对象?也许可以在一个方法里,比如:

a.many_b.addList(b) #This doesn't exist

2 个回答

1

我想你想要的是一种批量插入的功能,对吧?

据我所知,这个功能在Django的最新版本中可以用,但在1.3版本里是没有的!

你可以看看这个教程:http://www.caktusgroup.com/blog/2011/09/20/bulk-inserts-django/

5

来自文档:

>>> john = Author.objects.create(name="John")
>>> paul = Author.objects.create(name="Paul")
>>> george = Author.objects.create(name="George")
>>> ringo = Author.objects.create(name="Ringo")
>>> entry.authors.add(john, paul, george, ringo)

所以如果你有一个列表,可以使用参数展开的方式:

a.many_b.add(*list_of_b)

撰写回答