考虑以下:
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从未执行过,因此在上述示例中似乎可以完成工作?
ROLLBACK TRANSACTION
COMMIT TRANSACTION
我认为事务会立即回滚并在发生错误时立即丢弃。
不,一旦发生错误,事务不会回滚。但是您可能正在使用应用此策略的客户端应用程序。
例如,如果您使用的是mysql命令行客户端,则它通常会在发生错误时停止执行并退出。在事务进行过程中退出确实会导致其回滚。
在编写自己的应用程序时,可以控制回滚策略,但是有一些例外:
除这些条件外,如果调用生成错误的命令,则错误会照常返回,并且您可以随意执行任何操作,包括无论如何都要提交事务。