MySQL : transaction within a stored procedure(MySQL:存储过程中的事务)
问题描述
我的存储过程的基本结构是,
BEGIN.. 声明语句 ..开始交易;.. 查询 1 .... 查询 2 .... 查询 3 ..犯罪;结尾<块引用>
MySQL 版本: 5.1.61-0ubuntu0.11.10.1-log
目前,如果查询 2"失败,则提交查询 1"的结果.
- 如果任何查询失败,我如何回滚事务?
看一看 http://dev.mysql.com/doc/refman/5.0/en/declare-handler.html
基本上你声明错误处理程序将调用回滚
开始交易;声明 SQLEXCEPTION 的退出处理程序开始回滚;退出程序;结尾;犯罪;The basic structure of my stored procedure is,
BEGIN
.. Declare statements ..
START TRANSACTION;
.. Query 1 ..
.. Query 2 ..
.. Query 3 ..
COMMIT;
END
MySQL version: 5.1.61-0ubuntu0.11.10.1-log
Currently, if 'query 2' fails, result of 'query 1' is committed.
- How can I rollback the transaction if any of the query fails?
Take a look at http://dev.mysql.com/doc/refman/5.0/en/declare-handler.html
Basically you declare error handler which will call rollback
START TRANSACTION;
DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
ROLLBACK;
EXIT PROCEDURE;
END;
COMMIT;
这篇关于MySQL:存储过程中的事务的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:MySQL:存储过程中的事务
基础教程推荐
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 带更新的 sqlite CTE 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
