如果未达到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;
我注意到该事务自动回滚,并且记录插入尝试失败。
如果我没有ROLLBACK TRANSACTION
像上面一样提供错误处理程序或错误检查,是否安全,因为它COMMIT
TRANSACTION从未执行过,因此在上述示例中似乎可以完成工作?
我认为事务会立即回滚并在发生错误时立即丢弃。
回答:
不,一旦发生错误,事务不会回滚。但是您可能正在使用应用此策略的客户端应用程序。
例如,如果您使用的是mysql命令行客户端,则它通常会在发生错误时停止执行并退出。在事务进行过程中退出确实会导致其回滚。
在编写自己的应用程序时,可以控制回滚策略,但是有一些例外:
- 退出(即从数据库断开连接)总是回滚正在进行的事务
- 死锁或锁定等待超时隐式导致回滚
除这些条件外,如果调用生成错误的命令,则错误会照常返回,并且您可以随意执行任何操作,包括无论如何都要提交事务。
以上是 如果未达到COMMIT TRANSACTION,则会自动回滚 的全部内容, 来源链接: utcz.com/qa/406611.html