溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql基礎四 存儲過程

發(fā)布時間:2020-06-01 19:38:41 來源:網絡 閱讀:369 作者:lzf05303774 欄目:MySQL數據庫

一、存儲過程:變量的聲明和賦值。
delimiter $

create procedure p1()

begin

declare age int default 18;

    set age :=age+20;或者   set age =age+20

select age from dual;

end$

調用存儲過程:call p1(); 其結果是如下:

mysql基礎四 存儲過程

二、存儲過程:if 控制語句。
delimiter $
create procedure p2()
begin

declare age int default 18;
if age>=18 then
 select '已成年' ;
else 
 select '未成年';
end if;

end$
調用存儲過程:call p2(); 其結果是如下:
mysql基礎四 存儲過程

三、存儲過程:輸入參數。
計算一個矩形的面積,并判斷是胖fat? 瘦then? 還是方square?
delimiter $
create procedure p3(w int ,h int)
begin
select concat('area:',w*h);

if w > h then
  select 'fat';
elseif w < h then
  select 'then';    
else 
  select 'square';
end if;

end$

四、存儲過程:while循環(huán)

求1到100的和。
delimiter $
create procedure p100()
begin
declare total int default 0;
declare num int default 0;
while num<=100 do

set total=total+num;
set num=num+1;

end while;

select total;
end$

調用存儲過程:call p100(); 其結果是如下:
mysql基礎四 存儲過程

五、存儲過程:輸出參數:
求1到n的和。
delimiter $
create procedure p8(in n int ,out total int)
begin
set total=0;
declare num int default 0;
while num<=n do

set total=total+num;
set num=num+1;

end while;

end$

調用存儲過程:call p8(100,@sumary); select @sumary; 其結果是如下:

mysql基礎四 存儲過程

mysql基礎四 存儲過程

六、存儲過程:輸入輸出參數:
delimiter $
create procedure p9(inout age int)
begin
set age =age+20;
end $

調用存儲過程:set @currentage=18; call p9(@currentage) ;select @currentage; 其結果是如下:

mysql基礎四 存儲過程

七、存儲過程:case控制語句:
delimiter $
create procedure p10()
begin

declare pos int default 0;

set pos=floor(4*rand()) ;

case pos
when 1 then select 'haha';
when 2 then select 'hehe';
else select 'heihei';
end case;

end $

八、存儲過程:repeat控制語句:
delimiter $
create procedure p11()
begin

declare i int default 0;
declare total int default 0;

repeat 
    set i=i+1;
    set total =total +i;
until i>=100 end repeat;
select total;

end$

九、調用存儲過程 call:

call procedure_Name();

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI