【问题标题】:Django: Saving multiple ManyToMany fields within a transactionDjango:在事务中保存多个多对多字段
【发布时间】:2012-01-10 17:34:30
【问题描述】:

这是我的模型的表示:

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 对象列表。还有一个与Bs 相关的A 对象。像这样的:

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

【问题讨论】:

    标签: python django model manytomanyfield


    【解决方案1】:

    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)
    

    【讨论】:

    • 谢谢!不知道参数扩展。如果整个视图都在一个事务中,这个调用是在那个事务中执行的吗?
    • @santiagobasulto 是的,事务中间件应该将所有写入放在一个事务中,包括这个。
    【解决方案2】:

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

    据我所知,这仅在 Django TRUNK 中可用,而不是在 1.3 中!

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

    【讨论】:

    • 是的,类似的。我会看看。谢谢!
    猜你喜欢
    • 2014-02-26
    • 1970-01-01
    • 1970-01-01
    • 2018-09-30
    • 2023-04-02
    • 2014-10-02
    • 2019-08-05
    • 1970-01-01
    • 2011-02-05
    相关资源
    最近更新 更多