gpt4 book ai didi

python - 在 django 中引发异常的 transaction.rollback() 的正确方法

转载 作者:太空狗 更新时间:2023-10-29 21:22:11 25 4
gpt4 key购买 nike

我正在使用 Django 1.7.1 和 python 2.7,我正在做一些需要在事务内的 POST 请求,实际上我正在使用 @transaction.atomic() 装饰器,它使整个函数都在事务中。

据我所知,这个装饰器类似于 commit_on_success 并在出现数据库错误时进行回滚。

是否可以引发自定义异常,使事务回滚但不使用保存点?我想在回滚完成时返回一个 HttpResponse,解释事务未完成的原因。

我有这个。

@transaction.atomic()
def salida_de_almacen(request):
if request.method == 'POST':
try:
folio = request.POST['folio'] #Folio de la orden
epccoma = request.POST['epc'] #EPCs separados por coma
if folio is None or epccoma is None:
return HttpResponse('Datos Incompletos',status=400)
detalles = ODetalle.objects.filter(orden__folio=folio)
epcs = epccoma.replace(' ','').split(',')
inventario = Inventario.objects.filter(epc__in=epcs)
mal = '' # Items incompletos
for d in detalles:
for i in inventario:
if i.producto.item == d.producto.item:
d.cantidad_entregada+=i.cantidad
i.delete()
if d.cantidad_entregada<d.cantidad_ordenada:
mal+='%s,' % d.producto.item
if mal != '':

>>>> #raise Exception?? <<<<---- I WANT TO RISE AN EXCEPTION HERE TO ROLLBACK THE TR.

return HttpResponse('Items Incompletos: '+mal,status=400)
for d in detalles:
d.status=2 #Status completo
d.save()
return HttpResponse(serial_folio,status=200) # Todo bien
except Exception as e:
return HttpResponse(e.message,status=500)
else:
...

最佳答案

在这种情况下 - 删除装饰器,您可以在 View 中包装部分代码:

try:
with transaction.atomic():
# ...
if mal != '':
raise IntegrityError

except IntegrityError:
handle_exception()

在调用 handle_exception() 时,在 atomic 中尝试的任何操作都已经安全回滚。

https://docs.djangoproject.com/en/dev/topics/db/transactions/#django.db.transaction.atomic

关于python - 在 django 中引发异常的 transaction.rollback() 的正确方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26918115/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com