激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MySQL存儲過程圖文實例講解

MySQL存儲過程圖文實例講解

2022-03-09 22:27程裕強 Mysql

雖然MySQL的存儲過程一般情況下是不會使用到的,但是在一些特殊場景中,還是有需求的,下面這篇文章主要給大家介紹了關于MySQL存儲過程的相關資料,需要的朋友可以參考下

MySQL存儲過程

存儲過程是數據庫的一個重要的功能,MySQL 5.0以前并不支持存儲過程,這使得MySQL在應用上大打折扣。好在MySQL 5.0開始支持存儲過程,這樣即可以大大提高數據庫的處理速度,同時也可以提高數據庫編程的靈活性。

 

MySQL存儲過程的創建

語法

CREATE PROCEDURE 過程名([[IN|OUT|INOUT] 參數名 數據類型[,[IN|OUT|INOUT] 參數名 數據類型…]]) [特性 ...] 過程體

DELIMITER //
CREATE PROCEDURE myproc(OUT s int)
  BEGIN
    SELECT COUNT(*) INTO s FROM students;
  END
  //
DELIMITER ;

分隔符

MySQL默認以";"為分隔符,如果沒有聲明分割符,則編譯器會把存儲過程當成SQL語句進行處理,因此編譯過程會報錯,所以要事先用“DELIMITER //”聲明當前段分隔符,讓編譯器把兩個"//"之間的內容當做存儲過程的代碼,不會執行這些代碼;“DELIMITER ;”的意為把分隔符還原。

參數

存儲過程根據需要可能會有輸入、輸出、輸入輸出參數,如果有多個參數用","分割開。MySQL存儲過程的參數用在存儲過程的定義,共有三種參數類型,IN,OUT,INOUT:

IN參數的值必須在調用存儲過程時指定,在存儲過程中修改該參數的值不能被返回,為默認值OUT:該值可在存儲過程內部被改變,并可返回INOUT:調用時指定,并且可被改變和返回

過程體

過程體的開始與結束使用BEGIN與END進行標識。

MySQL存儲過程圖文實例講解

 

1、簡單實例

create procedure demo.p_test1()
begin
-- 使用 declare語句聲明一個變量
declare id int default 0;
declare name varchar(50) default '';
-- 使用set語句給變量賦值
set id=7521;
-- 將users表中id=1的名稱賦值給username
select ename into name from demo.emp where empno=id;
-- 返回變量
select name;
end;

MySQL存儲過程圖文實例講解

 

2、通過游標遍歷結果集

create table demo.test(
	id int,
	cnt varchar(50)
)
create procedure demo.p_test2()
-- 通過游標遍歷結果集
begin
-- 聲明變量
declare id int default 0;
declare name varchar(50) default '';
declare done boolean default 1;
-- 聲明游標
declare rs cursor for SELECT deptno,dname from demo.dept ;
-- 定義異常:
declare continue handler for SQLSTATE '02000' SET done = 0; 
-- 打開游標
open rs;
delete from demo.test;
while done do 
	begin
	  fetch rs into id,name;
    INSERT into demo.test SELECT e.deptno,count(1) from demo.emp e WHERE e.deptno =id group by e.deptno;
   end ;
end while;
-- 關閉游標
close rs;
end;
call demo.p_test2();

MySQL存儲過程圖文實例講解

SELECT * from  demo.test;

MySQL存儲過程圖文實例講解

 

總結

到此這篇關于MySQL存儲過程講解的文章就介紹到這了,更多相關MySQL存儲過程內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/chengyuqiang/article/details/122562302

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成年性羞羞视频免费观看无限 | 日韩黄色片免费看 | 黄网站在线免费 | 亚洲欧美日韩精品久久亚洲区色播 | 毛片在线免费视频 | 国产羞羞视频在线观看 | 88xx成人永久免费观看 | 精品国产专区 | 欧美视频一区二区三区在线观看 | 九九色在线观看 | 免费淫视频 | 欧美精品成人 | 激情视频导航 | 亚洲第一激情 | 黄污视频在线看 | 成人一区二区三区四区 | 日韩在线视频一区二区三区 | 激情综合视频 | 欧美成人一二区 | 亚洲aⅴ免费在线观看 | 免费观看一区二区三区视频 | 亚洲亚色| av电影在线观看网址 | 久久亚洲春色中文字幕久久 | 高清视频一区二区 | 毛片韩国 | 久久综合伊人 | 国产毛片网站 | www.成人免费 | 毛片118极品美女写真 | 92自拍视频 | 电影一级毛片 | 欧美一级片一区 | 国产黄色录像片 | 久久99亚洲精品 | 精品国产一区二区三区久久久 | 国产亚洲精品久久久久久久久久 | 久久靖品 | 在线a | 一级毛片免费的 | 毛片免费在线观看视频 |