標籤:
create procedure sys_message_user_for_busbase()begin -- 聲明一個標誌done, 用來判斷遊標是否遍曆完成 DECLARE done INT DEFAULT 0; -- 聲明一個變數,用來存放從遊標中提取的資料 -- 特別注意這裡的名字不能與由遊標中使用的列明相同,否則得到的資料都是NULL DECLARE tid varchar(50) DEFAULT NULL; DECLARE tname varchar(50) DEFAULT NULL; DECLARE thead varchar(255) DEFAULT NULL; DECLARE tmobile varchar(255) DEFAULT NULL; -- 聲明遊標對應的 SQL 陳述式 DECLARE cur CURSOR FOR select id,shop_name, mobile_phone,shop_logo from hx_busbase; -- 在遊標迴圈到最後會將 done 設定為 1 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1; -- 執行查詢 open cur; -- 遍曆遊標每一行 REPEAT -- 把一行的資訊存放在對應的變數中 FETCH cur INTO tid,tname, thead,tmobile; if not done then -- 這裡就可以使用 tname, tpass 對應的資訊了if (select count(1) from hx_message_user where uid=tid) = 0 THENINSERT INTO hx_message_user(id,head,mobile,username,uid,remark) VALUES(tid,thead,tmobile,tname,tid,"busbase");end if; #select tid,tname, tpass,(select count(1) from btable where id=tid) as count; end if; UNTIL done END REPEAT; CLOSE cur;end
#執行
call sys_message_user_for_busbase();
mysql 預存程序複製A表資料到B表