小编典典

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

mysql

考虑以下:

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;

题:

我注意到该事务自动回滚,并且记录插入尝试失败。

如果我没有ROLLBACK TRANSACTION像上面一样提供错误处理程序或错误检查,是否安全,因为它COMMIT TRANSACTION从未执行过,因此在上述示例中似乎可以完成工作?

我认为事务会立即回滚并在发生错误时立即丢弃。


阅读 451

收藏
2020-05-17

共1个答案

小编典典

不,一旦发生错误,事务不会回滚。但是您可能正在使用应用此策略的客户端应用程序。

例如,如果您使用的是mysql命令行客户端,则它通常会在发生错误时停止执行并退出。在事务进行过程中退出确实会导致其回滚。

在编写自己的应用程序时,可以控制回滚策略,但是有一些例外:

  • 退出(即从数据库断开连接)总是回滚正在进行的事务
  • 死锁或锁定等待超时隐式导致回滚

除这些条件外,如果调用生成错误的命令,则错误会照常返回,并且您可以随意执行任何操作,包括无论如何都要提交事务。

2020-05-17