亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MYSQL存儲過程即常用邏輯知識點總結

2020-01-18 20:43:14
字體:
來源:轉載
供稿:網友

Mysql存儲過程

1.創建存儲過程語法(格式)

DELIMITER $CREATE PROCEDURE 存儲過程名A(IN 傳入參數名a INT,IN 傳入參數名b VARCHAR(20),OUT 返回參數名c INT)BEGIN  內容..........END $

解析:

  • IN 代表傳入的參數,定義傳入參數名,并且后面跟上傳入參數類型(INT,VARCHAR,DOUBLE,........)
  • OUT 代表存儲過程執行完返回的數據,定義參數名,并且后面跟上參數類型(INT,VARCHAR,DOUBLE,........)
  • INOUT 代表既可以傳入也可以返回 ,定義參數名,并且后面跟上參數類型(INT,VARCHAR,DOUBLE,........)

2.存儲過程內具體語法與邏輯

A.定義變量語法:

DECLARE 變量名a 參數類型(INT,VARCHAR(20),BOOLEAN,........) [DEFAULT NULL];

注:可以在參數類型后面加 DEFAULT NULL; 來設置初始值。

B.變量賦值:

方式1(直接對變量進行賦值):

SET 定義的變量a = NEW();

方式2(sql查詢的結果直接賦值給變量):

SELECT `student`.age INTO 定義的變量a FROM `student` WHERE...........

方式3(sql查詢的結果直接賦值給多個變量):

SELECT `student`.name AS 定義的變量a,`student`.age AS 定義的變量b INTO 定義的變量a,定義的變量b FROM `student` ...............

c.邏輯判斷:

#IF判斷:          IF 條件語句(3>5) THEN         條件為TRUE時執行.........;      END IF;  #IF ELSE判斷:      IF 條件(a>0) THEN        條件為(a>0)時執行........;      ELSE IF 條件(a<0) THEN         條件為(a<0)時執行.......;      ELSE         其它執行.......;      END IF;

D.游標,(LOOP)循環:

#例.單游標循環:create procedure my_procedure() -- 創建存儲過程begin -- 開始存儲過程declare my_id varchar(32); -- 自定義變量1declare my_name varchar(50); -- 自定義變量2DECLARE done INT DEFAULT FALSE; -- 自定義控制游標循環變量,默認falseDECLARE cur CURSOR FOR ( SELECT id, name FROM t_people ); -- 定義游標并輸入結果集DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 綁定控制變量到游標,游標循環結束自動轉true OPEN cur; -- 打開游標 posLoop: LOOP -- 開始循環體,myLoop為自定義循環名,結束循環時用到  FETCH cur into my_id, my_name; -- 將游標當前讀取行的數據順序賦予自定義變量12     IF done THEN -- 判斷是否繼續循環        LEAVE posLoop; -- 結束循環    END IF;  -- 自己要做的事情,在 sql 中直接使用自定義變量即可  UPDATE t_user SET c_name = my_name WHERE id = my_id and rtrim(ltrim(c_name)) = ''; -- 左右去空格   COMMIT; -- 提交事務 END LOOP posLoop; -- 結束自定義循環體 CLOSE cur; -- 關閉游標END; -- 結束存儲過程
#例.多游標循環:create procedure my_procedure() -- 創建存儲過程begin -- 開始存儲過程declare my_id varchar(32); -- 自定義變量1declare my_name varchar(50); -- 自定義變量2DECLARE done INT DEFAULT FALSE; -- 自定義控制游標循環變量,默認falseDECLARE cur_1 CURSOR FOR ( SELECT id, name FROM t_people ); -- 定義游標并輸入結果集DECLARE cur_2 CURSOR FOR ( SELECT id_2,name_2 FROM t_people_2); --定義游標并輸入結果集DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 綁定控制變量到游標,游標循環結束自動轉true OPEN cur_1; -- 打開游標 posLoop: LOOP -- 開始循環體,myLoop為自定義循環名,結束循環時用到  FETCH cur_1 into my_id, my_name; -- 將游標當前讀取行的數據順序賦予自定義變量12     IF done THEN -- 判斷是否繼續循環        LEAVE posLoop; -- 結束循環    END IF;  -- 自己要做的事情,在 sql 中直接使用自定義變量即可  UPDATE ..........;  --自己要做的具體操作 END LOOP posLoop; -- 結束自定義循環體 CLOSE cur_1; -- 關閉游標  SET done = FALSE;  -- 因為當第一個游標遍歷完后其值被handler設置為TRUE了,如果不用set把它設置為 FALSE ,那么第二個游標就不會遍歷了。(最好是在每個打開游標的操作前都用該語句,以確保游標能真正遍歷)  OPEN cur_2; -- 打開游標 posLoop_2: LOOP -- 開始循環體,myLoop為自定義循環名,結束循環時用到  FETCH cur_2 into my_id, my_name; -- 將游標當前讀取行的數據順序賦予自定義變量12     IF done THEN -- 判斷是否繼續循環        LEAVE posLoop_2; -- 結束循環    END IF;  -- 自己要做的事情,在 sql 中直接使用自定義變量即可  INSERT ..........;   --自己要做的具體操作 END LOOP posLoop_2; -- 結束自定義循環體 CLOSE cur_2; -- 關閉游標END; -- 結束存儲過程

3.存儲過程的調用

#調用沒有返回值的存儲過程CALL 存儲過程名(參數.....);#調用有返回值的存儲過程(獲得返回值)CALL 存儲過程名(@aaa);SELECT @aaa;

4.刪除存儲過程

DROP PROCEDURE 存儲過程名; 

5.注意事項

存儲過程中的分號(;)很重要,盡量不要省略。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成一区二区| 国产成人精品日本亚洲专区61| 国产精品日本精品| 亚洲国产精品美女| 国内外成人免费激情在线视频网站| 亚洲图片欧美日产| 久久九九免费视频| 日韩在线国产精品| 91av在线免费观看视频| 国外成人在线直播| 九九热这里只有精品6| 欧美激情一区二区三区在线视频观看| 亚洲欧洲美洲在线综合| 国产精品亚洲美女av网站| 亚洲成人av在线播放| 91久久久久久久久久久| 国产精品午夜一区二区欲梦| 亚洲网站在线看| 狠狠色噜噜狠狠狠狠97| 欧美成人合集magnet| 91精品国产综合久久香蕉922| 亚洲石原莉奈一区二区在线观看| 欧美精品aaa| 91中文精品字幕在线视频| xxx一区二区| 亚洲日韩欧美视频| 亚洲免费视频观看| 亚洲自拍偷拍网址| 久久精品国产久精国产思思| 亚洲最大的网站| 国产一级揄自揄精品视频| 亚洲黄色免费三级| 国产一区二区视频在线观看| 日韩成人在线免费观看| 欧美日韩国产999| 国产成人涩涩涩视频在线观看| 成人免费看黄网站| 国产精彩精品视频| 亚洲午夜精品视频| 国产精品欧美激情在线播放| 久久国产天堂福利天堂| 狠狠躁夜夜躁人人躁婷婷91| 亚洲成年人在线播放| 国产精品久久久91| 欧美精品18videosex性欧美| 国产精品自在线| 久久久成人的性感天堂| 欧美大荫蒂xxx| 91精品国产91久久久久久最新| 2021久久精品国产99国产精品| 日韩人在线观看| 国产精品欧美日韩| 国产综合在线观看视频| 97在线视频免费观看| 欧美大片免费观看在线观看网站推荐| 欧美大片在线免费观看| 日韩美女av在线免费观看| 国产精品亚洲精品| 深夜精品寂寞黄网站在线观看| 国产精品自拍小视频| 一区二区三区四区在线观看视频| 亚洲国产第一页| 2021久久精品国产99国产精品| 青青久久av北条麻妃海外网| 日韩中文字幕在线精品| 亚洲va欧美va国产综合剧情| 国产精品福利观看| 亚洲色图狂野欧美| 性欧美激情精品| 九色精品免费永久在线| 亚洲午夜性刺激影院| 热re91久久精品国99热蜜臀| 久久久久久久91| 久久久久久久久久久网站| 日韩高清有码在线| 亚洲电影在线看| 成人性生交大片免费观看嘿嘿视频| 久久精品国产成人精品| 国产日韩欧美一二三区| 亚洲人午夜色婷婷| 欧美精品成人91久久久久久久| 96国产粉嫩美女| 色综合导航网站| 亚洲国产成人在线视频| 欧美激情综合色综合啪啪五月| 欧美日韩国产丝袜美女| 亚洲人成网站999久久久综合| 欧美日韩裸体免费视频| 91精品国产色综合| 久久影视电视剧免费网站| 日韩精品高清视频| 成人综合网网址| 国产精品成人aaaaa网站| 久久免费在线观看| 国产xxx69麻豆国语对白| 日韩精品在线免费| 国产精品入口日韩视频大尺度| 久久久av免费| 亚洲一区二区三区久久| 久久成年人免费电影| 国产精品视频一区二区三区四| 欧美电影在线观看| 最近中文字幕日韩精品| 美女视频久久黄| 日韩精品极品毛片系列视频| 亚洲码在线观看| 久久成人一区二区| 国产亚洲欧美一区| 欧美激情va永久在线播放| 欧美精品免费在线| 欧美日韩亚洲系列| 成人免费视频网址| 欧美视频二区36p| 国产精品第8页| 亚洲色图综合久久| 欧美视频免费在线观看| 中文字幕一区二区三区电影| 国产精品视频区1| 国产视频自拍一区| 亚洲欧美在线x视频| 亚洲欧洲美洲在线综合| 国产在线观看一区二区三区| 欧美日韩在线视频一区| 亚洲成人a级网| 亚洲性无码av在线| 91精品国产成人www| 欧美精品在线免费观看| 久久影院免费观看| 亚洲自拍高清视频网站| 国产日韩精品视频| 色爱精品视频一区| 2018日韩中文字幕| 久久久久久国产精品三级玉女聊斋| 亚洲一区二区三区在线视频| 国产精品自产拍在线观看| 精品亚洲夜色av98在线观看| 中文字幕精品一区二区精品| 久久综合伊人77777蜜臀| 国产精品露脸av在线| 日韩av黄色在线观看| 国产精品久久久久福利| 久久久久久久久中文字幕| 日本国产精品视频| 亚洲综合中文字幕在线观看| 亚洲精品v欧美精品v日韩精品| 51ⅴ精品国产91久久久久久| 日韩在线视频二区| 欧美夫妻性视频| 国产一区二区三区在线看| 欧美精品日韩三级| 伊人久久五月天| 热门国产精品亚洲第一区在线| 国产亚洲欧美日韩精品| 91欧美日韩一区| 国产亚洲精品日韩| 亚洲精品电影网| 国产精品女人网站| 91精品国产高清自在线| 国产999精品视频| 国产精品久久9| 韩国欧美亚洲国产| 欧美日韩成人在线视频| 国产一区二区美女视频| 欧美激情一区二区三区在线视频观看|