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 - 使用form進行頁面跳轉,但是很慢,如何加一個Loading?2. python 計算兩個時間相差的分鐘數,超過一天時計算不對3. angular.js - 輸入郵箱地址之后, 如何使其自動在末尾添加分號?4. javascript - 后臺管理系統左側折疊導航欄數據較多,怎么樣直接通過搜索去定位到具體某一個菜單項位置,并展開當前菜單5. docker-machine添加一個已有的docker主機問題6. docker-compose中volumes的問題7. angular.js - angularjs 注入模塊報錯 很怪異... 求解惑8. javascript - ES6規范下 repeat 函數報錯 Invalid count value9. javascript - html5的data屬性怎么指定一個function函數呢?10. html5 - 為什么使使用vue cli 腳手架,post-css 沒有自動對css3屬性自動添加瀏覽器前綴呢?
