本文整理匯總了Python中django.db.transaction.savepoint_commit方法的典型用法代碼示例。如果您正苦於以下問題:Python transaction.savepoint_commit方法的具體用法?Python transaction.savepoint_commit怎麽用?Python transaction.savepoint_commit使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類django.db.transaction
的用法示例。
在下文中一共展示了transaction.savepoint_commit方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: update_or_add
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def update_or_add(self, **kwargs):
assert kwargs, 'update_or_add() must be passed at least one keyword argument'
defaults = kwargs.pop('defaults', {})
obj = get_first(self.filter(**kwargs))
result = (obj, False, True)
create = False
if not obj:
obj = self.model()
result = (obj, True, False)
create = True
try:
params = dict([(k, v) for k, v in kwargs.items() if '__' not in k])
params.update(defaults)
for attr, val in params.items():
if hasattr(obj, attr):
setattr(obj, attr, val)
sid = transaction.savepoint()
obj.save(force_update=not create)
if not create:
self.add(obj)
transaction.savepoint_commit(sid)
return result
except IntegrityError, e:
transaction.savepoint_rollback(sid)
示例2: bulk_insert
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def bulk_insert(cursor, variant_arch_id, rpm_id, content_category_id, sigkey_id, path_id):
sql = add_returning("""INSERT INTO %s (variant_arch_id, rpm_id, sigkey_id, content_category_id, path_id)
VALUES (%%s, %%s, %%s, %%s, %%s)""" % ComposeRPM._meta.db_table)
try:
sid = transaction.savepoint()
cursor.execute(sql, [variant_arch_id, rpm_id, sigkey_id, content_category_id, path_id])
if connection.features.can_return_id_from_insert:
insert_id = connection.ops.fetch_returned_insert_id(cursor)
else:
insert_id = connection.ops.last_insert_id(cursor, ComposeRPM._meta.db_table, "id")
except IntegrityError:
transaction.savepoint_rollback(sid)
cursor.execute("SELECT %s FROM %s WHERE variant_arch_id=%%s AND rpm_id=%%s"
% ("id", ComposeRPM._meta.db_table),
[variant_arch_id, rpm_id])
insert_id = int(cursor.fetchone()[0])
transaction.savepoint_commit(sid)
return insert_id
示例3: create
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def create(self, validated_data):
try:
hosts = self.add_hosts()
groups = self.add_groups()
self.set_host_groups()
self.set_group_children()
self.set_group_hosts()
except serializers.ValidationError as e:
transaction.savepoint_rollback(self._save_point)
raise e
transaction.savepoint_commit(self._save_point)
return Inventory(hosts=hosts, groups=groups)
示例4: update_or_create
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def update_or_create(self, **kwargs):
"""
updates, creates or gets based on the kwargs. Works like get_or_create but in addition will update
the kwargs specified in defaults and returns a third value to indicate if an update happened
:param kwargs:
:return:
"""
assert kwargs, 'update_or_create() must be passed at least one keyword argument'
obj, created = self.get_or_create(**kwargs)
defaults = kwargs.pop('defaults', {})
if created:
return obj, True, False
else:
try:
needs_save = False
params = dict([(k, v) for k, v in kwargs.items() if '__' not in k])
params.update(defaults)
for attr, val in params.items():
if hasattr(obj, attr):
setattr(obj, attr, val)
# sid = transaction.savepoint()
obj.save(force_update=True)
# transaction.savepoint_commit(sid)
return obj, False, True
except IntegrityError, e:
# transaction.savepoint_rollback(sid)
try:
return self.get(**kwargs), False, False
except self.model.DoesNotExist:
raise e
# Update the related instance or add it. The toMany equivalent to update_or_create
示例5: get_or_create
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def get_or_create(self, **kwargs):
"""
Looks up an object with the given kwargs, creating one if necessary.
Returns a tuple of (object, created), where created is a boolean
specifying whether an object was created.
"""
assert kwargs, \
'get_or_create() must be passed at least one keyword argument'
defaults = kwargs.pop('defaults', {})
lookup = kwargs.copy()
for f in self.model._meta.fields:
if f.attname in lookup:
lookup[f.name] = lookup.pop(f.attname)
try:
self._for_write = True
return self.get(**lookup), False
except self.model.DoesNotExist:
try:
params = dict([(k, v) for k, v in kwargs.items() if '__' not in k])
params.update(defaults)
obj = self.model(**params)
sid = transaction.savepoint(using=self.db)
obj.save(force_insert=True, using=self.db)
transaction.savepoint_commit(sid, using=self.db)
return obj, True
except IntegrityError as e:
transaction.savepoint_rollback(sid, using=self.db)
exc_info = sys.exc_info()
try:
return self.get(**lookup), False
except self.model.DoesNotExist:
# Re-raise the IntegrityError with its original traceback.
six.reraise(*exc_info)
示例6: transfer_money
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def transfer_money(_from, _to, quota):
if _from.money < 15:
raise ValueError("連手續費都付不起,請回吧!!")
_from.money = _from.money - 15
_from.save()
sid = transaction.savepoint()
try:
_from.money = _from.money - quota
if _from.money < 0:
raise ValueError("超額提領!")
_from.save()
_to.money = _to.money + quota
if _to.money > 100000:
raise ValueError("超額儲存!")
_to.save()
transaction.savepoint_commit(sid)
except ValueError as e:
logger.error("金額操作錯誤, 訊息:<{}>".format(e))
transaction.savepoint_rollback(sid)
except Exception as e:
logger.error("其他錯誤,訊息:<{}>".format(e))
transaction.savepoint_rollback(sid)
示例7: bulk_insert
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def bulk_insert(cursor, rpm_nevra, filename, srpm_nevra=None,
srpm_commit_hash=None, srpm_commit_branch=None):
nvra = parse_nvra(rpm_nevra)
if srpm_nevra:
srpm_name = parse_nvra(srpm_nevra)["name"]
else:
srpm_name = nvra["name"]
sql = add_returning("""INSERT INTO %s (name, epoch, version, release, arch, srpm_nevra, srpm_name, filename, srpm_commit_hash, srpm_commit_branch)
VALUES (%%s, %%s, %%s, %%s, %%s, %%s, %%s, %%s, %%s, %%s)""" % RPM._meta.db_table)
try:
sid = transaction.savepoint()
RPM.check_srpm_nevra(rpm_nevra, srpm_nevra)
cursor.execute(sql, [nvra["name"], nvra["epoch"], nvra["version"], nvra["release"],
nvra["arch"], srpm_nevra, srpm_name, filename, srpm_commit_hash,
srpm_commit_branch])
if connection.features.can_return_id_from_insert:
insert_id = connection.ops.fetch_returned_insert_id(cursor)
else:
insert_id = connection.ops.last_insert_id(cursor, RPM._meta.db_table, "id")
except (IntegrityError, ValidationError):
transaction.savepoint_rollback(sid)
cursor.execute("""SELECT %s FROM %s WHERE name=%%s AND epoch=%%s AND
version=%%s and release=%%s AND arch=%%s""" % ("id", RPM._meta.db_table),
[nvra["name"], nvra["epoch"], nvra["version"], nvra["release"], nvra["arch"]])
insert_id = int(cursor.fetchone()[0])
transaction.savepoint_commit(sid)
return insert_id
示例8: atomic
# 需要導入模塊: from django.db import transaction [as 別名]
# 或者: from django.db.transaction import savepoint_commit [as 別名]
def atomic(using=None):
sid = transaction.savepoint(using=using)
try:
yield
except IntegrityError:
transaction.savepoint_rollback(sid, using=using)
raise
else:
transaction.savepoint_commit(sid, using=using)