欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django關(guān)于事務(wù)transaction.atomic()的使用方式

 更新時間:2023年08月24日 09:43:17   作者:天下·第二  
這篇文章主要介紹了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ù)

類視圖 (整個函數(shù)使用事務(wù),@transaction.atomic裝飾器)

class MyView(View):
    @transaction.atomic
    # transaction.atomic裝飾器可以保證該函數(shù)中所有的數(shù)據(jù)庫操作都在一個事務(wù)中。
    def post(self, request):
        # 數(shù)據(jù)庫操作1。。。
        # 數(shù)據(jù)庫操作2。。。
        return HttpResponse('ok')

類視圖 (函數(shù)體事務(wù),保存點的使用)

class MyView2(View):
    @transaction.atomic
    def post(self, request):
        # 設(shè)置事務(wù)保存點
        s1 = transaction.savepoint()   # 可以設(shè)置多個保存點
        # 數(shù)據(jù)庫操作。。。
        # 事務(wù)回滾 (如果發(fā)生異常,就回滾事務(wù))
        transaction.savepoint_rollback(s1)  # 可以回滾到指定的保存點
        # 提交事務(wù) (如果沒有異常,就提交事務(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ù)會安全

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é)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • PyTorch中常見損失函數(shù)的使用詳解

    PyTorch中常見損失函數(shù)的使用詳解

    損失函數(shù),又叫目標(biāo)函數(shù),是指計算機(jī)標(biāo)簽值和預(yù)測值直接差異的函數(shù),本文為大家整理了PyTorch中常見損失函數(shù)的簡單解釋和使用,希望對大家有所幫助
    2023-06-06
  • python中常用的九種預(yù)處理方法分享

    python中常用的九種預(yù)處理方法分享

    這篇文章給大家分享了python中常用的九種預(yù)處理方法,對大家學(xué)習(xí)或使用python具有一定的參考價值,有需要的朋友們可以一起來看看。
    2016-09-09
  • PyCharm 2020.2下配置Anaconda環(huán)境的方法步驟

    PyCharm 2020.2下配置Anaconda環(huán)境的方法步驟

    這篇文章主要介紹了PyCharm 2020.2下配置Anaconda環(huán)境的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 十個常見的Python腳本詳細(xì)介紹及代碼舉例

    十個常見的Python腳本詳細(xì)介紹及代碼舉例

    這篇文章主要給大家介紹了十個常見的Python腳本的相關(guān)資料,包括批量重命名文件、下載網(wǎng)頁圖片、發(fā)送郵件通知、讀取和寫入CSV文件、爬取網(wǎng)頁數(shù)據(jù)、自動化測試、圖像處理、數(shù)據(jù)可視化以及創(chuàng)建簡單的Web應(yīng)用,需要的朋友可以參考下
    2024-11-11
  • Python異常與錯誤處理詳細(xì)講解

    Python異常與錯誤處理詳細(xì)講解

    這篇文章主要介紹了Python異常與錯誤處理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • python使用openpyxl庫讀寫Excel表格的方法(增刪改查操作)

    python使用openpyxl庫讀寫Excel表格的方法(增刪改查操作)

    這篇文章主要介紹了python使用openpyxl庫讀寫Excel表格的方法(增刪改查操作),本文通過實例圖文相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • 教你使用Pandas直接核算Excel中的快遞費(fèi)用

    教你使用Pandas直接核算Excel中的快遞費(fèi)用

    文中仔細(xì)說明了怎么根據(jù)賬單核算運(yùn)費(fèi).首先要確定運(yùn)費(fèi)規(guī)則,然后根據(jù)運(yùn)費(fèi)規(guī)則編寫代碼,生成核算列(快遞費(fèi) = 省份*重量),最后輸入賬單,進(jìn)行核算.將腳本件生成EXE文件,就可以使用啦,需要的朋友可以參考下
    2021-05-05
  • Python實現(xiàn)的查詢mysql數(shù)據(jù)庫并通過郵件發(fā)送信息功能

    Python實現(xiàn)的查詢mysql數(shù)據(jù)庫并通過郵件發(fā)送信息功能

    這篇文章主要介紹了Python實現(xiàn)的查詢mysql數(shù)據(jù)庫并通過郵件發(fā)送信息功能,可實現(xiàn)Python針對mysql的查詢與宕機(jī)信息通過郵件發(fā)送的相關(guān)操作技巧,需要的朋友可以參考下
    2018-05-05
  • Python內(nèi)置函數(shù)delattr的具體用法

    Python內(nèi)置函數(shù)delattr的具體用法

    本篇文章主要介紹了Python內(nèi)置函數(shù)delattr的具體用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • Python部署web開發(fā)程序的幾種方法

    Python部署web開發(fā)程序的幾種方法

    本篇文章主要介紹了Python部署web開發(fā)程序的幾種方法,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-05-05

最新評論