玩蛇网提供最新Python编程技术信息以及Python资源下载!

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_err
finally:
    cur.close()
    dbConn.close()

出现异常时,rollback没有回滚2个create相关的指令。
现在我需要rollback建库和建表指令应该怎么做?

DDL VS DML

基本概念

DML 才能 rollback

直接drop

玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd13711.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2017年05月21日 - 22时14分03秒 发布自玩蛇网

您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules