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. android自带时钟应用的这个效果是怎么做的2. 前端 - 提问关于background-image不显示的问题3. mysql sql where id in(25,12,87) 结果集如何用按照 25 12 87排序?4. javascript - 如何在外部点击,跳转到网页后,显示指定的模块。5. javascript - 在top.jsp点击退出按钮后,right.jsp进行页面跳转,跳转到login.jsp6. javascript - app中集成轻量级富文本编辑器?7. css - 关于background-position百分比的问题?8. html5 - 如何禁止百度转码?9. 使用未定义的常量user_id-假定为“user_id”10. phpstudy v8打开数据库就出错,而phpstudy 2018不会

网公网安备