根據select的內容來批量修改一個表的欄位
/*判斷是否存在,如果存在就刪除*/
drop procedure if exists tempProcedure_Test;/*取一個系統中絕對不會用到的儲存過程名稱*/
/*建立臨時儲存過程*/
create procedure tempProcedure_Test()
BEGIN
declare isDone int default 0; /*判斷是否還有記錄*/
declare intNumber int default 30000;/*用於自增的變數*/
declare tempId char(36); /*每條記錄迴圈時的臨時ID*/
declare folderIds cursor for select A.ID from mus_gateway_deduct_transaction as A;/*取出來所有需要迴圈的資料*/
declare continue handler for not FOUND set isDone = 1;/*如果不存在就設定為1,即為true*/
open folderIds; /*OPEN*/
REPEAT /*開始迴圈資料*/
fetch folderIds into tempId;
if not isDone THEN
update mus_gateway_deduct_transaction set id=intNumber where id=tempId;
set intNumber=intNumber+1;
end if;
until isDone end repeat;
close folderIds; /*CLOSE,對應上面的open folderIds;*/
END;
call tempProcedure_Test();/*呼叫下這個臨時的儲存過程*/
drop procedure tempProcedure_Test; /*使用完畢後要刪除垃圾*/
---------------------
作者:紅木葉
來源:CSDN
原文:https://blog.csdn.net/qq897958555/article/details/79376715
版權宣告:本文為博主原創文章,轉載請附上博文連結!