MySQL:存储过程中的事务

MySQL : transaction within a stored procedure(MySQL:存储过程中的事务)
本文介绍了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:存储过程中的事务的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)