我正在使用Django 1.7.1和python 2.7,我正在做一些POST请求,这些请求需要在事务中,实际上我正在使用@transaction.atomic()
decorator,它使整个函数位于事务中。
据我所知,这个decorator类似于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:
...
在这种情况下-remove decorator,可以在视图中包装部分代码:
调用handle_exception()时,
atomic
内尝试的任何操作都将安全回滚。https://docs.djangoproject.com/en/dev/topics/db/transactions/#django.db.transaction.atomic
我已将数据库配置为
'ATOMIC_REQUESTS'
,因此中的每个请求也嵌套在事务中。我在寻找一种不引发异常而回滚的方法。我知道,这不是最初的问题,但为了记录,以下是有效的(django 1.11):
相关问题 更多 >
编程相关推荐