学习SQL 事务

说明:

事务实在数据库上按照一定的扩机顺序执行的任务序列,即可以由用户手动执行,也可以有某种数据库程序自动执行。
事务实际上就是对数据库的一个或者多个更改。当你在某张表上创建或者删除记录时,你就已经使用事务了 ,控制事务以保证数据完整性,并对数据库错误做出处理,对数据库来说非常重要

实践中,通常会将很多SQL查询组合在一起,并将其作为某个事务一部分来执行


事务的属性


事务具有以下四个标准属性,通常用缩略词ACID来表示:

- 原子性: 保证任务中的所有操作都执行完毕;否则,事务会出现错误时终止,并回滚之前所有操作到原始状态.
- 一致性: 保证不同的事务相互独立,透明的进行
- 隔离性: 保证不同的事务相互独立,透明的执行
- 持久性:即使出现故障,之前成功执行的事务的结果也会持久存在

事务控制


有四个命令用于控制事务:
- COMMIT : 提交更改;
- ROLLBACK : 回滚更改;
- SAVEPOINT : 在事务内部创建一系列ROLLBACK的还原点;
- SET TRANSACTION : 命令事务;

1.COMMIT 命令

COMMIT 命令用于保存事务对数据库所做的更改。

COMMIT 命令会将自上次 COMMIT 命令或者 ROLLBACK 命令执行以来所有的事务都保存到数据库中。

COMMIT 命令的语法如下所示:
   commit;
学习SQL 事务_第1张图片

DELETE FROM CUSTOMERS
     WHERE AGE = 25;
COMMIT;

学习SQL 事务_第2张图片


2.ROLLBACK 命令

学习SQL 事务_第3张图片
学习SQL 事务_第4张图片

DELETE FROM CUSTOMERS
     WHERE AGE = 25;
ROLLBACK;

学习SQL 事务_第5张图片


3.SAVEPOINT 命令

SAVEPOINT 是事务中的一个状态点,使得我们可以将事务回滚至特定的点,而不是将整个事务都撤销。

SAVEPOINT 命令的记录如下所示:

SAVEPOINT SAVEPOINT_NAME;

该命令只能在事务语句之间创建保存点(SAVEPOINT)。ROLLBACK 命令可以用于撤销一系列的事务。

回滚至某一保存点的语法如下所示:

ROLLBACK TO SAVEPOINT_NAME;

下面的示例中,你计划从 CUSTOMERS 表中删除三条不同的记录,并在每次删除之前创建一个保存点(SAVEPOINT),从而使得你可以在任何任何时候回滚到任意的保存点,以恢复数据至其原始状态。
学习SQL 事务_第6张图片

SQL> SAVEPOINT SP1;
Savepoint created.
SQL> DELETE FROM CUSTOMERS WHERE ID=1;
1 row deleted.
SQL> SAVEPOINT SP2;
Savepoint created.
SQL> DELETE FROM CUSTOMERS WHERE ID=2;
1 row deleted.
SQL> SAVEPOINT SP3;
Savepoint created.
SQL> DELETE FROM CUSTOMERS WHERE ID=3;
1 row deleted.

现在,三次删除操作已经生效了,如果此时你改变主意决定回滚至名字为 SP2 的保存点,由于 SP2 于第一次删除操作之后创建,所以后两次删除操作将会被撤销。

SQL> ROLLBACK TO SP2;
Rollback complete.

注意,由于你将数据库回滚至 SP2,所以只有第一次删除真正起效了:

学习SQL 事务_第7张图片

RELEASE SAVEPOINT 命令

RELEASE SAVEPOINT 命令用于删除先前创建的保存点。

RELEASE SAVEPOINT 的语法如下所示:

RELEASE SAVEPOINT SAVEPOINT_NAME;

保存点一旦被释放,你就不能够再用 ROLLBACK 命令来撤销该保存点之后的事务了。


4.SET TRANSACTION 命令

SET TRANSACTION 命令可以用来初始化数据库事务,指定随后的事务的各种特征。

例如,你可以将某个事务指定为只读或者读写
 
 SET TRANSACTION 命令的语法如下所示:

SET TRANSACTION [ READ WRITE | READ ONLY ];

你可能感兴趣的:(sql)