事物处理可以用来维护数据库的完整性,它保证成批的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;