如何回滚循环保存存储过程中的数据 [英] How to rollback loop save data in stored procedure

查看:199
本文介绍了如何回滚循环保存存储过程中的数据的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我使用storedprocedure调用我的查询来运行insert。如果我想回滚多行循环插入是否有任何方法?



我尝试过:



i m using storedprocedure call my query to run insert. If i want to rollback multiple row loop insert is it have any ways?

What I have tried:

BEGIN
    START TRANSACTION;
 
    CALL StoredProcedure1(@1, @2)
 
    CALL StoredProcedure2(@1, @2, etc )
 
    DECLARE EXIT HANDLER FOR SQLEXCEPTION 
        BEGIN
            ROLLBACK;
            EXIT PROCEDURE;
        END;
 
    COMMIT;
END

推荐答案

交易中的所有SQL语句都是一起。无论是1000万个不同的表中的一行还是1000万行。当事务提交时, ll在该事务期间发生更改保存,当它回滚时,所有更改将被回滚。就这么简单。
All SQL statements inside your transaction are together. Whether that's one row or 10 million rows from 10 million different tables. When a transaction commits, all changes during that transaction are saved, when it is rolled back, all changes are rolled back. It is that simple.


这篇关于如何回滚循环保存存储过程中的数据的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆