python的MySQLdb包rollback对create语句无效吗?
高洛峰
高洛峰 2017-04-18 10:26:01
[Python讨论组]

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

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(2)
天蓬老师

DDL VS DML

基本概念

DML 才能 rollback

高洛峰

直接drop

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号