Django關(guān)于事務(wù)transaction.atomic()的使用方式
Django事務(wù)transaction.atomic()使用
導(dǎo)入需要使用的包
from django.shortcuts import render from django.http import HttpResponse from django.views import View from django.db import transaction # 導(dǎo)入事務(wù)
類視圖 (整個(gè)函數(shù)使用事務(wù),@transaction.atomic裝飾器)
class MyView(View): @transaction.atomic # transaction.atomic裝飾器可以保證該函數(shù)中所有的數(shù)據(jù)庫(kù)操作都在一個(gè)事務(wù)中。 def post(self, request): # 數(shù)據(jù)庫(kù)操作1。。。 # 數(shù)據(jù)庫(kù)操作2。。。 return HttpResponse('ok')
類視圖 (函數(shù)體事務(wù),保存點(diǎn)的使用)
class MyView2(View): @transaction.atomic def post(self, request): # 設(shè)置事務(wù)保存點(diǎn) s1 = transaction.savepoint() # 可以設(shè)置多個(gè)保存點(diǎn) # 數(shù)據(jù)庫(kù)操作。。。 # 事務(wù)回滾 (如果發(fā)生異常,就回滾事務(wù)) transaction.savepoint_rollback(s1) # 可以回滾到指定的保存點(diǎn) # 提交事務(wù) (如果沒(méi)有異常,就提交事務(wù)) transaction.savepoint_commit(s1) # 返回應(yīng)答 return HttpResponse('ok')
函數(shù)體中使用
def func(request): with transaction.atomic(): sid = transaction.savepoint() try: serializer.is_valid(raise_exception=True) comment = serializer.save() handle_obj_files(comment, request) visitor_order.epilogue.add(comment) visitor_order.status = 'complete' visitor_order.save() except Exception as e: transaction.savepoint_rollback(sid) return api_bad_request(str(e)) else: transaction.savepoint_commit(sid) data = VisitorOrderRetrieveSerializer(visitor_order).data return api_success(data=data)
此方法和方法二類似
為什么需要with transaction.atomic()
django的事務(wù)回滾操作
1.為什么需要事務(wù)回滾操作?
2.SQL事務(wù)是什么?
3. 數(shù)據(jù)會(huì)安全
4. django為什么需要with transaction.atomic()?
with transaction.atomic(): issue_field = After.objects.get(id=issue_field_id) issue_field.is_abandoned = True issue_field.save() # if set is_abandoned to True, set all field value with this field is_abandoned to True all_issue_field_value = AfterSales.objects.update().filter(field=issue_id) for issue= in all_issue: issue.is_abandoned = True issue.save()
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
PyTorch中常見(jiàn)損失函數(shù)的使用詳解
損失函數(shù),又叫目標(biāo)函數(shù),是指計(jì)算機(jī)標(biāo)簽值和預(yù)測(cè)值直接差異的函數(shù),本文為大家整理了PyTorch中常見(jiàn)損失函數(shù)的簡(jiǎn)單解釋和使用,希望對(duì)大家有所幫助2023-06-06PyCharm 2020.2下配置Anaconda環(huán)境的方法步驟
這篇文章主要介紹了PyCharm 2020.2下配置Anaconda環(huán)境的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09十個(gè)常見(jiàn)的Python腳本詳細(xì)介紹及代碼舉例
這篇文章主要給大家介紹了十個(gè)常見(jiàn)的Python腳本的相關(guān)資料,包括批量重命名文件、下載網(wǎng)頁(yè)圖片、發(fā)送郵件通知、讀取和寫(xiě)入CSV文件、爬取網(wǎng)頁(yè)數(shù)據(jù)、自動(dòng)化測(cè)試、圖像處理、數(shù)據(jù)可視化以及創(chuàng)建簡(jiǎn)單的Web應(yīng)用,需要的朋友可以參考下2024-11-11python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)
這篇文章主要介紹了python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作),本文通過(guò)實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05教你使用Pandas直接核算Excel中的快遞費(fèi)用
文中仔細(xì)說(shuō)明了怎么根據(jù)賬單核算運(yùn)費(fèi).首先要確定運(yùn)費(fèi)規(guī)則,然后根據(jù)運(yùn)費(fèi)規(guī)則編寫(xiě)代碼,生成核算列(快遞費(fèi) = 省份*重量),最后輸入賬單,進(jìn)行核算.將腳本件生成EXE文件,就可以使用啦,需要的朋友可以參考下2021-05-05Python實(shí)現(xiàn)的查詢mysql數(shù)據(jù)庫(kù)并通過(guò)郵件發(fā)送信息功能
這篇文章主要介紹了Python實(shí)現(xiàn)的查詢mysql數(shù)據(jù)庫(kù)并通過(guò)郵件發(fā)送信息功能,可實(shí)現(xiàn)Python針對(duì)mysql的查詢與宕機(jī)信息通過(guò)郵件發(fā)送的相關(guān)操作技巧,需要的朋友可以參考下2018-05-05Python內(nèi)置函數(shù)delattr的具體用法
本篇文章主要介紹了Python內(nèi)置函數(shù)delattr的具體用法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11