Django: сохранение нескольких полей ManyToMany в транзакции - PullRequest
6 голосов
/ 01 декабря 2011

это представление моих моделей:

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 объект, который будет связан с этими 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 ]

5 голосов
/ 01 декабря 2011

Из документов :

>>> 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 голос
/ 01 декабря 2011

Полагаю, вы хотите что-то вроде массовой вставки, верно?

Насколько я знаю, это доступно только в Django TRUNK, а не в 1.3!

посмотрите учебник: http://www.caktusgroup.com/blog/2011/09/20/bulk-inserts-django/

...