python的MySQLdb包rollback對create語句無效嗎?
問題描述
業務需要用腳本自動創建數據庫表,并注冊到一個注冊表中。環境是python2.7+mysql5.6+MySQLdb代碼如下,其中createSchemaCmd是create schemasql指令,createTableCmd是create table指令,registerTableCmd是insert table指令
dbConn = DBOHelper.getConnect(DB_HOST, DB_Account, DB_PSW)cur = dbConn.cursor()try: for cmd in [createSchemaCmd, createTableCmd, registerTableCmd]:rst = cur.execute(cmd)dbConn.commit()except MySQLdb.MySQLError, sql_err: dbConn.rollback() print 'Mysql Error %d: %s' % (sql_err.args[0], sql_err.args[1]) raise sql_errfinally: cur.close() dbConn.close()
出現異常時,rollback沒有回滾2個create相關的指令。現在我需要rollback建庫和建表指令應該怎么做?
問題解答
回答1:DDL VS DML
基本概念
DML 才能 rollback
回答2:直接drop
相關文章:
1. javascript - sublime快鍵鍵問題2. javascript - immutable配合react提升性能?3. vue.js - Vue 如何像Angular.js watch 一樣監聽數據變化4. 配置Apache時,添加對PHP的支持時語法錯誤5. css - 寫頁面遇到個布局問題,求大佬們幫解答,在線等,急!~6. javascript - nodejs關于進程間發送句柄的一點疑問7. javascript - 移動端上不能實現拖拽布局嗎?8. phpstudy8.1支持win11系統嗎?9. 實現bing搜索工具urlAPI提交10. Apache 已經把網站根目錄的改為allow from all了,但是服務器還是不能訪問?

網公網安備