Django框架orM與自定義SQL語句混合事務控制操作
本文實例講述了Django框架orM與自定義SQL語句混合事務控制操作。分享給大家供大家參考,具體如下:
用單純的ORM 或者單純的自定義SQL語句,都比較好控制事務。在前面的一篇文章中已經(jīng)講過Django事務小結(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語句的事務,只要任何一條語句出錯,就會回滾.
那么,如果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混合事務,就可以這么控制了。
希望本文所述對大家基于Django框架的Python程序設(shè)計有所幫助。
相關(guān)文章
Matplotlib.pyplot 三維繪圖的實現(xiàn)示例
這篇文章主要介紹了Matplotlib.pyplot 三維繪圖的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07
人工智能學習Pytorch數(shù)據(jù)集分割及動量示例詳解
這篇文章主要為大家介紹了人工智能學習Pytorch數(shù)據(jù)集分割及動量示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2021-11-11
自己搭建resnet18網(wǎng)絡(luò)并加載torchvision自帶權(quán)重的操作
這篇文章主要介紹了自己搭建resnet18網(wǎng)絡(luò)并加載torchvision自帶權(quán)重的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05
python正則表達式之re.match()與re.search()的用法及區(qū)別
本文主要介紹了python正則表達式之re.match()與re.search()的用法及區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08
python創(chuàng)建多個logging日志文件的方法實現(xiàn)
本文主要介紹了python創(chuàng)建多個logging日志文件的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07
Python用K-means聚類算法進行客戶分群的實現(xiàn)
這篇文章主要介紹了Python用K-means聚類算法進行客戶分群的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08
Python數(shù)據(jù)分析的八種處理缺失值方法詳解
缺失值可能是數(shù)據(jù)科學中最不受歡迎的值,然而,它們總是在身邊。忽略缺失值也是不合理的,因此我們需要找到有效且適當?shù)靥幚硭鼈兊姆椒?/div> 2021-11-11最新評論

