本文實例講述了Django框架orM與自定義SQL語句混合事務控制操作。分享給大家供大家參考,具體如下:
用單純的ORM 或者單純的自定義SQL語句,都比較好控制事務。在前面的一篇文章中已經講過Django事務小結 ,但里面沒有提到在同一個方法里面既有ORM 又有 自定義SQL 語句的情況。
如果是單純的ORM ,可以這樣做,假設已經定義好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() .......
只有在程序成功執行,沒錯時,才會commit. 比如如果cat 保存出錯,那么user 就會回滾。
如果是單純的自定義SQL語句,可以通過如下方式實現
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)
用這種方式,實現自定義SQL語句的事務,只要任何一條語句出錯,就會回滾.
那么,如果ORM 與 自定義SQL 語句混合如何做呢,我在項目中結合了上面兩種方式。比如按如下的方式
@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程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。