mysql完成事務的提交和回滾實例。本站提示廣大學習愛好者:(mysql完成事務的提交和回滾實例)文章只能為提供參考,不一定能成為您想要的結果。以下是mysql完成事務的提交和回滾實例正文
mysql創立存儲進程的官方語法為:
START TRANSACTION | BEGIN [WORK]
COMMIT [WORK] [AND [NO] CHAIN] [[NO] RELEASE]
ROLLBACK [WORK] [AND [NO] CHAIN] [[NO] RELEASE]
SET AUTOCOMMIT = {0 | 1}
我這裡要解釋的mysql事務處置多個SQL語句的回滾情形。好比說在一個存儲進程中啟動一個事務,這個事務同時往三個表中拔出數據,每插完一張表須要斷定其能否操作勝利,假如不勝利則須要回滾,最初一張表斷定其拔出勝利以後commit。這裡須要留意的是不克不及直接應用事務的collback,如許是不克不及完成回滾的或許說能夠湧現不測的毛病。
那末我們須要的是一個前提斷定,好比loop,由於MySql默許是會主動提交的,所以我們不消擔憂rollback以後前提加入而沒有commit。
詳細mysql語句以下:
begin
loop_lable: loop
start transaction;
insert into table1(f_user_id) values(user_id);
if row_count() < 1 then
set @ret = -1;
rollback;
leave loop_label;
end if;
insert into table2(f_user_id) values(user_id);
if row_count() < 1 then
set @ret = -1;
rollback;
leave loop_label;
end if;
insert into table3(f_user_id) values(user_id);
if row_count() < 1 then
set @ret = -1;
rollback;
leave loop_label;
else
set @ret = 0;
commit;
leave loop_label;
end if;
end loop;
select @ret;
end