如何回滚循环保存存储过程中的数据 [英] How to rollback loop save data in stored procedure
本文介绍了如何回滚循环保存存储过程中的数据的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我使用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屋!
查看全文