管理事务处理

1.事务处理

使用事务处理,通过确保成批的SQL操作要么完全执行,要么完全不执行,来维护数据库的完整性。

事务处理是一种机制,用来管理必须成批执行的SQL操作,保证数据库不包含不完整的操作结果。

利用事务处理,可以保证一组操作不会中途停止,它们要么完全执行,要么完全不执行。

如果没有错误发生,整组语句提交给数据库表,如果发送错误,则进行回滚(回退,撤销),将数据库恢复到某个已知且安全的状态。

使用事务处理时,有几个反复出现的关键词。

下面是关于事务处理需要知道的几个术语:

事务(transacation):指一组SQL语句

回退(rollback):指撤销指定SQL语句的过程

提交(commit):指将未存储的SQL语句结果写入数据库表

保留点(savepoint):指事务处理中设置的临时占位符,可以对它发布回退

2.控制事务处理
SQL
--MySQL
START TRANSACTION
--SQL Server
BEGIN TRANSACTION
...
COMMIT TRANSACTION
2.1使用ROLLBACK

SQL的ROLLBACK命令用来回退SQL语句

SQL
DELETE FROM Ordes
ROLLBACK
2.2使用COMIT

一般的SQL语句都是针对数据库表直接执行和编写的。

这就是所谓的隐式提交,即提交操作是自动进行的。

在事务处理块中,提交不会隐式进行。

SQL
BEGIN TRANSACTION
DELETE OrderItems WHERE order_num = 12345
DELETE Orders WHERE order_num = 12345
COMMIT TRANSACTION
2.3使用保留点

使用简单的ROLLBACK和COMMIT语句,就可以写入或撤销整个事务。

但是,只对简单的事务才能这样做,复杂的事务可能需要部分提交或回退。

要支持回退部分事务,必须在事务处理块中的合适位置占位符。

这样,如果需要回退,可以回退到某个占位符。

在SQL中,这些占位符称为保留点。

SQL
--MySQL
SAVEPOINT delete1
--SQL Server
SAVE TRANSACTION delete1

提示:保留点越多越好

可以在SQL代码中设置任意多的保留点,越多越好。

保留点越多,你就越能灵活地进行回退

订阅评论
提醒
0 评论
最旧
最新 最多投票
内联反馈
查看所有评论
滚动至顶部