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

Django框架orM與自定義SQL語句混合事務(wù)控制操作

 更新時間:2019年06月27日 11:16:27   作者:輕舞肥羊  
這篇文章主要介紹了Django框架orM與自定義SQL語句混合事務(wù)控制操作,結(jié)合實例形式分析了同一個方法里面既有ORM又有自定義SQL 語句的情況下事務(wù)控制相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了Django框架orM與自定義SQL語句混合事務(wù)控制操作。分享給大家供大家參考,具體如下:

用單純的ORM 或者單純的自定義SQL語句,都比較好控制事務(wù)。在前面的一篇文章中已經(jīng)講過Django事務(wù)小結(jié) ,但里面沒有提到在同一個方法里面既有ORM 又有 自定義SQL 語句的情況。

如果是單純的ORM ,可以這樣做,假設(shè)已經(jīng)定義好model, User,Category。

from django.db import transaction
...
@commit_on_success
def save_test(request):
  user=User(name="aaa",age=30)
  user.save()
  cat=Category(id=2,name="cat001")
  cat.save()
  .......

只有在程序成功執(zhí)行,沒錯時,才會commit. 比如如果cat 保存出錯,那么user 就會回滾。

如果是單純的自定義SQL語句,可以通過如下方式實現(xiàn)

from django.db import connection, transaction
...
def batch_execsql(sqlarray):
  print sqlarray
  cursor = connection.cursor()
  ret=""
  try:
    for sql in sqlarray:
      cursor.execute(sql)
    transaction.commit_unless_managed()
  except Exception,e:
    ret=str(e)
  cursor.close()
  return ret
sqlarray=[]
sqlarray.append("insert into table .......")
sqlarray.append("update table set.......")
ret=batch_execsql(sqlarray)

用這種方式,實現(xiàn)自定義SQL語句的事務(wù),只要任何一條語句出錯,就會回滾.

那么,如果ORM 與 自定義SQL 語句混合如何做呢,我在項目中結(jié)合了上面兩種方式。比如按如下的方式

@commit_on_success
def save_company_callinfo(request):
  response=HttpResponse()
  try:
     #==orm 保存部分======
     ....
     model1.save()
     ....
     model2.save()
     ...
     #==自定義SQL 部分====
     sqlarray=[]
     sqlarray.append("insert into table .......")
     sqlarray.append("update table set.......")
     ret=batch_execsql(sqlarray)
     if len(ret)>0:
       transaction.rollback()
       response.write('{"status":"no","error":"%s"}' % ('add call information error',))
     else:
       response.write('{"status":"no","error":"%s"}' % ('',))
  except Exception,e:
     response.write('{"status":"no","error":"%s"}' % (str(e),))
  return response

這上面的過程可以自己修改成自己需要的,我用的是AJAX方式,因為我自己需要,但總體上ORM 與自定義SQL混合事務(wù),就可以這么控制了。

希望本文所述對大家基于Django框架的Python程序設(shè)計有所幫助。

相關(guān)文章

  • Python多進程與多線程的使用場景詳解

    Python多進程與多線程的使用場景詳解

    這篇文章主要給大家介紹了關(guān)于Python多進程與多線程使用場景的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 簡單介紹Python中的len()函數(shù)的使用

    簡單介紹Python中的len()函數(shù)的使用

    這篇文章主要簡單介紹了Python中的len()函數(shù)的使用,包括在四種情況下的使用小例子,是Python學(xué)習(xí)當中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-04-04
  • Python有參函數(shù)使用代碼實例

    Python有參函數(shù)使用代碼實例

    這篇文章主要介紹了Python有參函數(shù)使用代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • 遺傳算法之Python實現(xiàn)代碼

    遺傳算法之Python實現(xiàn)代碼

    本篇文章主要介紹了Python 遺傳算法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • 解析Anaconda創(chuàng)建python虛擬環(huán)境的問題

    解析Anaconda創(chuàng)建python虛擬環(huán)境的問題

    這篇文章主要介紹了Anaconda創(chuàng)建python虛擬環(huán)境,包括虛擬環(huán)境管理、虛擬環(huán)境中python包管理,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • Python爬取豆瓣視頻信息代碼實例

    Python爬取豆瓣視頻信息代碼實例

    這篇文章主要介紹了Python爬取豆瓣視頻信息代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • 對python sklearn one-hot編碼詳解

    對python sklearn one-hot編碼詳解

    今天小編就為大家分享一篇對python sklearn one-hot編碼詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • python無序鏈表刪除重復(fù)項的方法

    python無序鏈表刪除重復(fù)項的方法

    這篇文章主要介紹了python無序鏈表刪除重復(fù)項的方法,本文給大家介紹的非常詳細,具體一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • pip?install如何指定包的安裝路徑

    pip?install如何指定包的安裝路徑

    最近學(xué)習(xí)python需要用pip下載一些包,但是發(fā)現(xiàn)下載后在pycharm中根本導(dǎo)入不了,下面這篇文章主要給大家介紹了關(guān)于pip?install如何指定包的安裝路徑的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • 對numpy中的transpose和swapaxes函數(shù)詳解

    對numpy中的transpose和swapaxes函數(shù)詳解

    今天小編就為大家分享一篇對numpy中的transpose和swapaxes函數(shù)詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08

最新評論