您的位置:首页 > 数据库 > MySQL

MySQL控制事物处理

2018-03-13 16:03 267 查看
事物处理可以用来维护数据库的完整性,它保证成批的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;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: