當前位置:首頁 » 存儲配置 » mysql存儲過程中的循環

mysql存儲過程中的循環

發布時間: 2022-06-20 11:19:17

『壹』 Mysql 存儲過程 怎麼實現 循環sql語句

delimiter $$
mysql>
mysql> CREATE PROCEDURE myProc() //創建while循環的存儲過程 if分支語句示例
-> BEGIN
->
-> DECLARE i int;
-> SET i=1;
-> loop1: WHILE i<=10 DO
-> IF MOD(i,2)<>0 THEN /*Even number - try again*/
-> SELECT CONCAT(i," is an odd number");
-> END IF;
-> SET i=i+1;
-> END WHILE loop1;
-> END$$
Query OK, 0 rows affected (0.00 sec)

這種也可以

『貳』 mysql 存儲過程循環查詢

SELECT COUNT(DISTINCT(app_userId)) FROM

缺少 INTO關鍵字吧?

『叄』 mysql 使用存儲過程 循環查找數據

delimiter
$$
mysql>
mysql>
CREATE
PROCEDURE
myProc()
//創建while循環的存儲過程
if分支語句示例
->
BEGIN
->
->
DECLARE
i
int;
->
SET
i=1;
->
loop1:
WHILE
i<=10
DO
->
IF
MOD(i,2)<>0
THEN
/*Even
number
-
try
again*/
->
SELECT
CONCAT(i,"
is
an
odd
number");
->
END
IF;
->
SET
i=i+1;
->
END
WHILE
loop1;
->
END$$
Query
OK,
0
rows
affected
(0.00
sec)
這種也可以

『肆』 MySQL實現創建存儲過程並循環添加記錄的方法

本文實例講述了MySQL實現創建存儲過程並循環添加記錄的方法。分享給大家供大家參考,具體如下:
先創建,然後調用:
--
創建存儲過程
DELIMITER;//
create
procere
myproc()
begin
declare
num
int;
set
num=1;
while
num
<=
24
do
insert
into
t_calendar_hour(hourlist)
values(num);
set
num=num+1;
end
while;
commit;
end;//
--
調用存儲過程
CALL
myproc();
PS:這里再為大家推薦2款常用的sql在線工具供大家參考使用(包含SQL語句用法說明):
SQL在線壓縮/格式化工具:
http://tools.jb51.net/code/sql_format_compress
SQL代碼在線格式化美化工具:
http://tools.jb51.net/code/sqlcodeformat
更多關於MySQL相關內容感興趣的讀者可查看本站專題:《MySQL存儲過程技巧大全》、《MySQL常用函數大匯總》、《MySQL日誌操作技巧大全》、《MySQL事務操作技巧匯總》及《MySQL資料庫鎖相關技巧匯總》
希望本文所述對大家MySQL資料庫計有所幫助。

『伍』 mysql存儲過程里怎麼循環一張表

給你一個 參考

--存儲過程名和參數,參數中in表示傳入參數,out標示傳出參數,inout表示傳入傳出參數

create procere p_procerecode(in sumdate varchar(10))
begin
declare v_sql varchar(500); --需要執行的SQL語句
declare sym varchar(6);

declare var1 varchar(20);
declare var2 varchar(70);
declare var3 integer;

--定義游標遍歷時,作為判斷是否遍歷完全部記錄的標記
declare no_more_departments integer DEFAULT 0;

--定義游標名字為C_RESULT
DECLARE C_RESULT CURSOR FOR
SELECT barcode,barname,barnum FROM tmp_table;

--聲明當游標遍歷完全部記錄後將標志變數置成某個值
DECLARE CONTINUE HANDLER FOR NOT FOUND
SET no_more_departments=1;

set sym=substring(sumdate,1,6); --截取字元串,並將其賦值給一個遍歷

--連接字元串構成完整SQL語句,動態SQL執行後的結果記錄集,在MySQL中無法獲取,因此需要轉變思路將其放置到一個臨時表中(注意代碼中的寫法)。一般寫法如下:

-- 'Create TEMPORARY Table 表名(Select的查詢語句);
set v_sql= concat('Create TEMPORARY Table tmp_table(select aa as aacode,bb as aaname,count(cc) as ccnum from h',sym,' where substring(dd,1,8)=''',sumdate,''' group by aa,bb)');

set @v_sql=v_sql; --注意很重要,將連成成的字元串賦值給一個變數(可以之前沒有定義,但要以@開頭)
prepare stmt from @v_sql; --預處理需要執行的動態SQL,其中stmt是一個變數
EXECUTE stmt; --執行SQL語句
deallocate prepare stmt; --釋放掉預處理段

OPEN C_RESULT; --打開之前定義的游標
REPEAT --循環語句的關鍵詞
FETCH C_RESULT INTO VAR1, VAR2, VAR3; --取出每條記錄並賦值給相關變數,注意順序

--執行查詢語句,並將獲得的值付給一個變數 @oldaacode(注意如果以@開頭的變數可以不用通過declare語句事先聲明)
select @oldaacode:=vcaaCode from T_sum where vcaaCode=var1 and dtDate=sumdate;
if @oldaacode=var1 then --判斷
update T_sum set iNum=var3 where vcaaCode=var1 and dtDate=sumdate;
else
insert into T_sum(vcaaCode,vcaaName,iNum,dtDate) values(var1,var2,var3,sumdate);
end if;
UNTIL no_more_departments END REPEAT; --循環語句結束
CLOSE C_RESULT; --關閉游標

DROP TEMPORARY TABLE tmp_table; --刪除臨時表
end;

『陸』 mysql里的存儲過程是怎樣循環的

declare storeId varchar(10);
在存儲過程中創建游標,這個游標裡面存了你所有要循環的數據,集合:
declare diy_cursor cursor for
select store_id from t_b_store;

open diy_cursor;--打開游標
diy_loop:loop ---這里開始循環
FETCH diy_cursor into storeId; --提取本次循環的數據,保存在storeId中
if done = 1 then --done是在存儲過程開始的時候定義的一個整形變數
leave diy_loop;---如果游標中的數據提取完畢,就自動跳出這個循環end if;
----在這里用你循環取到的storeId做你想做的事情,就是寫你的sql啦---
end loop; --循環結束
close diy_loop; --關閉游標

『柒』 mysql中怎麼使用循環

delimiter $$// 定義結束符為 $$
drop procere if exists wk; // 刪除 已有的 存儲過程
create procere wk()// 創建新的存儲過程
begin
declare i int;// 變數聲明
set i = 1;
while i < 11 do // 循環體
insert into user_profile (uid) values (i);
set i = i +1;
end while;
end $$// 結束定義語句

// 調用

delimiter ;// 先把結束符 回復為;
call wk();

delimter : mysql 默認的 delimiter是; 告訴mysql解釋器,該段命令是否已經結束了,mysql是否可以執行了。

『捌』 mysql存儲過程為什麼會多循環一次

沒有多循環一次,只是循環結束後,循環控制變數會是終值的下一個,但是並沒有多執行一次循環體。

『玖』 mysql存儲過程中的問題以及觸發器和循環

分為3大循環:(1)if循環
if 條件 then
......
else
......
end if;
(2)while循環
while 條件 do
......
end while;
(3)loop循環
CREATE PROCEDURE myProc()
BEGIN
DECLARE i int;
SET i=0;
loop1: LOOP
SET i=i+1;
IF i>=10 THEN
LEAVE loop1;
ELSEIF MOD(i,2)=0 THEN
ITERATE loop1;
END IF;
SELECT CONCAT(i," is an odd number");
END LOOP loop1;
END;

『拾』 mysql sql中流程式控制制有for循環嗎

MySQL不支持FOR loops循環。

只有LOOP循環:

[begin_label:] LOOP

statement_list

END LOOP [end_label]

CREATE PROCEDURE doiterate(p1 INT)

BEGIN

label1: LOOP

SET p1 = p1 + 1;

IF p1 < 10 THEN

ITERATE label1;

END IF;

LEAVE label1;

END LOOP label1;

SET @x = p1;

END;

LOOP實現了一個簡單的循環結構,允許重復執行語句列表,該列表由一個或多個語句組成,每個語句以分號(;)分隔符結束。 循環中的語句將重復執行,直到循環終止。 一般情況,通過LEAVE終止循環。 在函數中,也可以使用RETURN,它完全退出函數,也同時終止循環。

(10)mysql存儲過程中的循環擴展閱讀

mysql流程式控制制結構:

順序結構:程序從上往下依次執行,

分支結構:程序從兩條或多條路徑中選中一條去執行,

循環結構:程序在滿足一定條件的基礎上,重復執行一段代碼。

分支結構

1、if函數

功能:實現簡單的雙分支

語法:

if(表達式1,表達式2,表達式3)

執行順序:

如果表達式1成立,則if函數返回表達式2的值,否則返回表達式3的值

應用:任何地方(在begin end中或外面都可以)

2、case結構

情況1:類似於java中的switch語句,一般用於實現等值判斷

語法:

CASE 變數|表達式|欄位

WHEN 要判斷的值 THEN 返回的值1或語句1;

WHEN 要判斷的值 THEN 返回的值2或語句2;

...

ELSE 要返回的值n或語句n;

END CASE;

情況2:類似於java中的多重IF語句,一般用於實現區間判斷

語法;

CASE

WHEN 要判斷的條件1 THEN 返回的值1或語句1;

WHEN 要判斷的條件2 THEN 返回的值2或語句2;

...

ELSE 要返回的值n或語句n;

END CASE;

熱點內容
演算法導論對數 發布:2025-03-19 07:30:58 瀏覽:144
sql字元串日期 發布:2025-03-19 07:30:52 瀏覽:730
編程求距離 發布:2025-03-19 07:30:52 瀏覽:979
win8無法訪問共享 發布:2025-03-19 07:30:49 瀏覽:28
個人電腦怎麼把伺服器放到公網 發布:2025-03-19 07:19:35 瀏覽:785
linux配置網路界面 發布:2025-03-19 07:10:10 瀏覽:900
安卓哪個手機最小 發布:2025-03-19 07:09:08 瀏覽:621
電腦無線網路怎麼打開伺服器 發布:2025-03-19 06:53:09 瀏覽:925
網頁緩存視頻下載 發布:2025-03-19 06:52:19 瀏覽:987
演算法實戰 發布:2025-03-19 06:52:14 瀏覽:515