事物处理可以用来维护数据库的完整性,它保证成批的MySQL操作要么完全执行,要不完全不执行。

事物处理需要知道的几个术语:

  • 事物(transaction) 指一组SQL语句
  • 回退(rollback)指撤销指定SQL语句的过程
  • 提交(commit)指将未存储的SQL语句结果写入数据库表中
  • 保留点(savepoint)指事物处理中设置的临时占位符,你可以对它发布回退(与回退整个事物不同,可以部分的回退)
使用ROLLBACK
START TRANSACTION;
DELETE FROM student;
SELECT * FROM student;
ROLLBACK;
SELECT * FROM student;

START TRANSACTION表示事物的开始,ROLLBACK表示撤销START TRANSACTION到ROLLBACK中间的操作。

student中的数据如下

+---------+-------------+-------+
| NO      | name        | grade |
+---------+-------------+-------+
| 2012000 | hudahai     |    99 |
| 2012001 | taoji       |    78 |
| 2012002 | zhouxiaojun |    89 |
+---------+-------------+-------+

SQL操作中第一个select语句的结果为

Empty set (0.00 sec)

第二个select语句的结果为

+---------+-------------+-------+
| NO      | name        | grade |
+---------+-------------+-------+
| 2012000 | hudahai     |    99 |
| 2012001 | taoji       |    78 |
| 2012002 | zhouxiaojun |    89 |
+---------+-------------+-------+

也就是回退到删除表之前的样子。

使用COMMIT

一般的MySQL语句都是针对数据库表执行和编写的。这就是所谓的隐含提交(implicitcommit),即提交(写或保存)操作是自动进行的。

但是在事物处理中,提交不会隐含地进行。为进行明确的提交,需要使用COMMIT语句。

比如有的时候提交数据,需要一下子添加好多条,而如果要求,一下子添加要么添加全部添加成功,要么全部添加失败,则此时可以用到COMMIT语句

START TRANSACTION;
INSERT INTO student VALUES(2012003,"gouzi",77);
INSERT INTO student VALUES(2012004,"rangdi",60);
COMMIT;

这两条语句有一条啊执行失败,则全部执行失败。而不被START TRANSACTION和COMMIT包围的多条insert语句,他们之间是没有关系的,一条的添加失败与否并不会影响另一条记录的添加的。

使用SAVEPOINT和ROLLBACK TO

简单的ROLLBACK和COMMIT语句就可以写入或撤销整个事物处理。对于复杂的事物处理,可能需要部分提交或回退。例如,一下子添加多条数据,可以找到添加失败的数据,然后后面再重新添加,而不需要全部重新添加了。为了完成这部分的操作,需要在事物处理块中合适的位置方式占位符,也称为保留点。

SAVEPOINT insert1;

每个保留点都取唯一的名字,以便在回退的时候,回退到正确的位置。

ROLLBACK TO insert1;