程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql完成事務的提交和回滾實例

mysql完成事務的提交和回滾實例

編輯:MySQL綜合教程

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 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved