如果未达到COMMIT TRANSACTION,则会自动回滚

问题描述

| 考虑以下:
START TRANSACTION;

BEGIN;

INSERT INTO prp_property1 (module_name,environment_name,NAME,VALUE) VALUES (\'\',\'production\',\'\',\'300000\');

/** Assume there is Syntax error sql here...**/
Blah blah blah

DELETE FROM prp_property1 WHERE environment_name = \'production\';

COMMIT TRANSACTION;
题: 我注意到该事务自动回滚,并且记录插入尝试失败。 如果我没有像上面的ѭ1一样提供错误处理程序或错误检查,那么由于上面的example2ѭ从未执行,似乎在上面的示例中正在执行此工作是否安全? 我认为事务会立即回滚并在发生错误时立即丢弃。     

解决方法

不,一旦发生错误,事务不会回滚。但是您可能正在使用应用此策略的客户端应用程序。 例如,如果您使用的是mysql命令行客户端,则它通常会在发生错误时停止执行并退出。在事务进行过程中退出确实会导致其回滚。 在编写自己的应用程序时,可以控制回滚策略,但是有一些例外: 退出(即与数据库断开连接)总是回滚正在进行的事务 死锁或锁定等待超时隐式导致回滚 除这些条件外,如果您调用生成错误的命令,该错误将照常返回,并且您可以随意执行任何操作,包括无论如何都要提交事务。     ,您可以使用过程来更有效地执行此操作。 在MySQL服务器中使用存储过程进行事务处理     ,使用Mysql存储过程
   BEGIN

   DECLARE exit handler for sqlexception
      BEGIN
      ROLLBACK;
   END;

   DECLARE exit handler for sqlwarning
     BEGIN
     ROLLBACK;
   END;

   START TRANSACTION;

   INSERT INTO prp_property1 (module_name,environment_name,NAME,VALUE) VALUES (\'\',\'production\',\'\',\'300000\');

   [ERROR]

   COMMIT;

   END
您可以设置警告或错误回滚,然后就不需要删除,事务将删除所有条目。     ,我想补充一下@MarkR已经说过的内容。假设InnoDB引擎发生了错误处理,如Mysql Server文档中所述      如果表空间中的文件空间不足,则会发生MySQL表已满错误,并且InnoDB回滚SQL语句。   事务死锁导致InnoDB回滚整个事务。   重复键错误会回滚SQL语句   一行太长的错误将回滚SQL语句。   其他错误大多数由MySQL代码层(在InnoDB存储引擎级别之上)检测到,并且它们回滚相应的SQL语句    我的理解也是,当Mysql会话结束时(php脚本结束时),所有未提交的内容都会回滚。我还必须找到一个非常可靠的消息来源来支持此声明,所以请不要相信我。     ,我已经测试了这三种情况; mySQL不会自动回滚。 事务死锁导致InnoDB回滚整个事务。 重复键错误会回滚SQL语句 一行太长的错误将回滚SQL语句。 除非您的应用程序显式调用\“ rollback \”,否则只有受影响的记录会失败,其余的记录会成功。     

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...