Django框架orM與自定義SQL語(yǔ)句混合事務(wù)控制操作
本文實(shí)例講述了Django框架orM與自定義SQL語(yǔ)句混合事務(wù)控制操作。分享給大家供大家參考,具體如下:
用單純的ORM 或者單純的自定義SQL語(yǔ)句,都比較好控制事務(wù)。在前面的一篇文章中已經(jīng)講過(guò)Django事務(wù)小結(jié) ,但里面沒(méi)有提到在同一個(gè)方法里面既有ORM 又有 自定義SQL 語(yǔ)句的情況。
如果是單純的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í)行,沒(méi)錯(cuò)時(shí),才會(huì)commit. 比如如果cat 保存出錯(cuò),那么user 就會(huì)回滾。
如果是單純的自定義SQL語(yǔ)句,可以通過(guò)如下方式實(shí)現(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)
用這種方式,實(shí)現(xiàn)自定義SQL語(yǔ)句的事務(wù),只要任何一條語(yǔ)句出錯(cuò),就會(huì)回滾.
那么,如果ORM 與 自定義SQL 語(yǔ)句混合如何做呢,我在項(xiàng)目中結(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
這上面的過(guò)程可以自己修改成自己需要的,我用的是AJAX方式,因?yàn)槲易约盒枰傮w上ORM 與自定義SQL混合事務(wù),就可以這么控制了。
希望本文所述對(duì)大家基于Django框架的Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Python多進(jìn)程與多線程的使用場(chǎng)景詳解
這篇文章主要給大家介紹了關(guān)于Python多進(jìn)程與多線程使用場(chǎng)景的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03簡(jiǎn)單介紹Python中的len()函數(shù)的使用
這篇文章主要簡(jiǎn)單介紹了Python中的len()函數(shù)的使用,包括在四種情況下的使用小例子,是Python學(xué)習(xí)當(dāng)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-04-04解析Anaconda創(chuàng)建python虛擬環(huán)境的問(wèn)題
這篇文章主要介紹了Anaconda創(chuàng)建python虛擬環(huán)境,包括虛擬環(huán)境管理、虛擬環(huán)境中python包管理,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03對(duì)python sklearn one-hot編碼詳解
今天小編就為大家分享一篇對(duì)python sklearn one-hot編碼詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07python無(wú)序鏈表刪除重復(fù)項(xiàng)的方法
這篇文章主要介紹了python無(wú)序鏈表刪除重復(fù)項(xiàng)的方法,本文給大家介紹的非常詳細(xì),具體一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01對(duì)numpy中的transpose和swapaxes函數(shù)詳解
今天小編就為大家分享一篇對(duì)numpy中的transpose和swapaxes函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08