您想退房
django.db.transaction.commit_manually。
http://docs.djangoproject.com/en/dev/topics/db/transactions/#django-db-
transaction-commit-
manually
因此,它将类似于:
from django.db import transaction@transaction.commit_manuallydef viewfunc(request): ... for item in items: entry = Entry(a1=item.a1, a2=item.a2) entry.save() transaction.commit()
只会提交一次,而不是每个save()。
在Django 1.3中,引入了上下文管理器。因此,现在您可以以类似的方式使用
transaction.commit_on_success() :
from django.db import transactiondef viewfunc(request): ... with transaction.commit_on_success(): for item in items: entry = Entry(a1=item.a1, a2=item.a2) entry.save()
在django
1.4中,
bulk_create添加了它,使您可以创建模型对象的列表,然后一次提交所有对象。
注意 使用批量创建时,不会调用save方法。
>>> Entry.objects.bulk_create([... Entry(headline="Django 1.0 Released"),... Entry(headline="Django 1.1 Announced"),... Entry(headline="Breaking: Django is awesome")... ])
在django 1.6中,引入了
transaction.atomic
,旨在取代现在的遗留函数
commit_on_success和
commit_manually。
从atom的django文档中:
原子既可以用作装饰器:
from django.db import transaction@transaction.atomicdef viewfunc(request): # This pre executes inside a transaction. do_stuff()
并作为上下文管理器:
from django.db import transactiondef viewfunc(request): # This pre executes in autocommit mode (Django's default). do_stuff() with transaction.atomic(): # This pre executes inside a transaction. do_more_stuff()



