MySQL控制事物处理
2018-03-13 16:03
267 查看
事物处理可以用来维护数据库的完整性,它保证成批的MySQL操作要么完全执行,要不完全不执行。
事物处理需要知道的几个术语:
事物(transaction) 指一组SQL语句
回退(rollback)指撤销指定SQL语句的过程
提交(commit)指将未存储的SQL语句结果写入数据库表中
保留点(savepoint)指事物处理中设置的临时占位符,你可以对它发布回退(与回退整个事物不同,可以部分的回退)
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语句。
比如有的时候提交数据,需要一下子添加好多条,而如果要求,一下子添加要么添加全部添加成功,要么全部添加失败,则此时可以用到COMMIT语句START TRANSACTION;
INSERT INTO student VALUES(2012003,"gouzi",77);
INSERT INTO student VALUES(2012004,"rangdi",60);
COMMIT;这两条语句有一条啊执行失败,则全部执行失败。而不被START TRANSACTION和COMMIT包围的多条insert语句,他们之间是没有关系的,一条的添加失败与否并不会影响另一条记录的添加的。
事物处理需要知道的几个术语:
事物(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;相关文章推荐
- MySQL事物处理
- Spring+hibernate+mysql事物不回滚的原因以及处理
- Spring+hibernate+mysql事物不回滚的原因以及处理
- MySQL事物控制
- Spring+hibernate+mysql事物不回滚的原因以及处理
- Spring+hibernate+mysql事物不回滚的原因以及处理
- mysql事物处理
- node.js 事物处理 mysql
- Spring+hibernate+mysql事物不回滚的原因以及处理
- Spring+hibernate+mysql事物不回滚的原因以及处理
- [Mysql]事物处理
- mysql 事物处理
- java 使用mysql事物处理问题
- Spring+hibernate+mysql事物不回滚的原因以及处理
- Spring+hibernate+mysql事物不回滚的原因以及处理
- 关于MySQL事物处理的问题
- mysql之commit,transaction事物控制
- mysql事物处理的知识点总结
- Spring+hibernate+mysql事物不回滚的原因以及处理
- Spring+hibernate+mysql事物不回滚的原因以及处理