標籤:判斷 思考 case 就刪除 until 語句 小程式 sel 開始
事情的原委:
今天遇到一個問題:一個資料表case_folder_info想要實現自訂排序功能,就在表裡新加了一個欄位SORT_NUMBER,由於表裡存在已有資料,所以這個SORT_NUMBER欄位都為空白,但要想實現上移、下移、置頂等功能的話,需要裡面有預設資料,所以我想給這個欄位裡預設有一些排序的值。
思考解決辦法:
1、用c#寫個小程式,然後取出來所有資料,UPDATE一遍,這個還得建立項目,添加資料庫連接字串,添加資料庫類庫引用,太麻煩。
2、用資料庫內建的命令列方式實現。
最終經過我頭腦的一番小鬥爭,雖然sql不太熟但還是決定嘗試一下吧。
sql實現的思路:
由於命令列中無法直接使用declare這樣使用變數,所以乾脆用非常現的方式來解決吧,先建一個臨時的預存程序,在預存程序中實現我要想的迴圈賦值,然後使用完後再刪除這個預存程序就可以了。
具體的sql語句:
/*判斷是否存在,如果存在就刪除*/
drop procedure if exists tempProcedure_Test;/*取一個系統中絕對不會用到的預存程序名稱*/
/*建立暫存預存程序*/
create procedure tempProcedure_Test()
BEGIN
declare isDone int default 0; /*判斷是否還有記錄*/
declare intNumber int default 1;/*用於自增的變數*/
declare tempId char(36); /*每條記錄迴圈時的臨時ID*/
declare folderIds cursor for select A.ID from case_folder_info 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 case_folder_info set SORT_NUMBER=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; /*使用完畢後要刪除垃圾*/
完畢,收工!
mysql批次更新資料,即:迴圈select記錄然後更新某一欄位