欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

MySQL控制事物处理

程序员文章站 2022-07-05 13:22:49
...

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