问题描述
|
考虑以下:
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 \”,否则只有受影响的记录会失败,其余的记录会成功。