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

时间:2011-12-01 15:14:29

标签: python django model manytomanyfield

这是我模特的代表:

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 s相关的单个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 个答案:

答案 0 :(得分:5)

From the docs

>>> 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)

答案 1 :(得分:1)

我想你想要的是一种批量插入吗?

据我所知,这只是在Django TRUNK中,不在1.3中!

查看一些教程: http://www.caktusgroup.com/blog/2011/09/20/bulk-inserts-django/