python的MySQLdb包rollback对create语句无效吗?

 lluuaalulua619 发布于 2022-10-25 10:31

业务需要用脚本自动创建数据库表,并注册到一个注册表中。
环境是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建库和建表指令应该怎么做?

2 个回答
  • 直接drop

    2022-10-26 23:19 回答
  • DDL VS DML

    基本概念

    DML 才能 rollback

    2022-10-26 23:19 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有