MYSQL存儲過程即常用邏輯知識點(diǎn)總結(jié)
更新時(shí)間:2019年08月29日 15:54:35 作者:MoMing
在本篇文章里小編給大家整理的是關(guān)于MYSQL存儲過程即常用邏輯知識點(diǎn),有需要的朋友們可以學(xué)習(xí)下。
Mysql存儲過程
1.創(chuàng)建存儲過程語法(格式)
DELIMITER $ CREATE PROCEDURE 存儲過程名A(IN 傳入?yún)?shù)名a INT,IN 傳入?yún)?shù)名b VARCHAR(20),OUT 返回參數(shù)名c INT) BEGIN 內(nèi)容.......... END $
解析:
- IN 代表傳入的參數(shù),定義傳入?yún)?shù)名,并且后面跟上傳入?yún)?shù)類型(INT,VARCHAR,DOUBLE,........)
- OUT 代表存儲過程執(zhí)行完返回的數(shù)據(jù),定義參數(shù)名,并且后面跟上參數(shù)類型(INT,VARCHAR,DOUBLE,........)
- INOUT 代表既可以傳入也可以返回 ,定義參數(shù)名,并且后面跟上參數(shù)類型(INT,VARCHAR,DOUBLE,........)
2.存儲過程內(nèi)具體語法與邏輯
A.定義變量語法:
DECLARE 變量名a 參數(shù)類型(INT,VARCHAR(20),BOOLEAN,........) [DEFAULT NULL];
注:可以在參數(shù)類型后面加 DEFAULT NULL; 來設(shè)置初始值。
B.變量賦值:
方式1(直接對變量進(jìn)行賦值):
SET 定義的變量a = NEW();
方式2(sql查詢的結(jié)果直接賦值給變量):
SELECT `student`.age INTO 定義的變量a FROM `student` WHERE...........
方式3(sql查詢的結(jié)果直接賦值給多個(gè)變量):
SELECT `student`.name AS 定義的變量a,`student`.age AS 定義的變量b INTO 定義的變量a,定義的變量b FROM `student` ...............
c.邏輯判斷:
#IF判斷: IF 條件語句(3>5) THEN 條件為TRUE時(shí)執(zhí)行.........; END IF; #IF ELSE判斷: IF 條件(a>0) THEN 條件為(a>0)時(shí)執(zhí)行........; ELSE IF 條件(a<0) THEN 條件為(a<0)時(shí)執(zhí)行.......; ELSE 其它執(zhí)行.......; END IF;
D.游標(biāo),(LOOP)循環(huán):
#例.單游標(biāo)循環(huán):create procedure my_procedure() -- 創(chuàng)建存儲過程 begin -- 開始存儲過程 declare my_id varchar(32); -- 自定義變量1 declare my_name varchar(50); -- 自定義變量2 DECLARE done INT DEFAULT FALSE; -- 自定義控制游標(biāo)循環(huán)變量,默認(rèn)false DECLARE cur CURSOR FOR ( SELECT id, name FROM t_people ); -- 定義游標(biāo)并輸入結(jié)果集 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 綁定控制變量到游標(biāo),游標(biāo)循環(huán)結(jié)束自動轉(zhuǎn)true OPEN cur; -- 打開游標(biāo) posLoop: LOOP -- 開始循環(huán)體,myLoop為自定義循環(huán)名,結(jié)束循環(huán)時(shí)用到 FETCH cur into my_id, my_name; -- 將游標(biāo)當(dāng)前讀取行的數(shù)據(jù)順序賦予自定義變量12 IF done THEN -- 判斷是否繼續(xù)循環(huán) LEAVE posLoop; -- 結(jié)束循環(huán) END IF; -- 自己要做的事情,在 sql 中直接使用自定義變量即可 UPDATE t_user SET c_name = my_name WHERE id = my_id and rtrim(ltrim(c_name)) = ''; -- 左右去空格 COMMIT; -- 提交事務(wù) END LOOP posLoop; -- 結(jié)束自定義循環(huán)體 CLOSE cur; -- 關(guān)閉游標(biāo) END; -- 結(jié)束存儲過程
#例.多游標(biāo)循環(huán):create procedure my_procedure() -- 創(chuàng)建存儲過程begin -- 開始存儲過程 declare my_id varchar(32); -- 自定義變量1 declare my_name varchar(50); -- 自定義變量2 DECLARE done INT DEFAULT FALSE; -- 自定義控制游標(biāo)循環(huán)變量,默認(rèn)false DECLARE cur_1 CURSOR FOR ( SELECT id, name FROM t_people ); -- 定義游標(biāo)并輸入結(jié)果集 DECLARE cur_2 CURSOR FOR ( SELECT id_2,name_2 FROM t_people_2); --定義游標(biāo)并輸入結(jié)果集 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 綁定控制變量到游標(biāo),游標(biāo)循環(huán)結(jié)束自動轉(zhuǎn)true OPEN cur_1; -- 打開游標(biāo) posLoop: LOOP -- 開始循環(huán)體,myLoop為自定義循環(huán)名,結(jié)束循環(huán)時(shí)用到 FETCH cur_1 into my_id, my_name; -- 將游標(biāo)當(dāng)前讀取行的數(shù)據(jù)順序賦予自定義變量12 IF done THEN -- 判斷是否繼續(xù)循環(huán) LEAVE posLoop; -- 結(jié)束循環(huán) END IF; -- 自己要做的事情,在 sql 中直接使用自定義變量即可 UPDATE ..........; --自己要做的具體操作 END LOOP posLoop; -- 結(jié)束自定義循環(huán)體 CLOSE cur_1; -- 關(guān)閉游標(biāo) SET done = FALSE; -- 因?yàn)楫?dāng)?shù)谝粋€(gè)游標(biāo)遍歷完后其值被handler設(shè)置為TRUE了,如果不用set把它設(shè)置為 FALSE ,那么第二個(gè)游標(biāo)就不會遍歷了。(最好是在每個(gè)打開游標(biāo)的操作前都用該語句,以確保游標(biāo)能真正遍歷) OPEN cur_2; -- 打開游標(biāo) posLoop_2: LOOP -- 開始循環(huán)體,myLoop為自定義循環(huán)名,結(jié)束循環(huán)時(shí)用到 FETCH cur_2 into my_id, my_name; -- 將游標(biāo)當(dāng)前讀取行的數(shù)據(jù)順序賦予自定義變量12 IF done THEN -- 判斷是否繼續(xù)循環(huán) LEAVE posLoop_2; -- 結(jié)束循環(huán) END IF; -- 自己要做的事情,在 sql 中直接使用自定義變量即可 INSERT ..........; --自己要做的具體操作 END LOOP posLoop_2; -- 結(jié)束自定義循環(huán)體 CLOSE cur_2; -- 關(guān)閉游標(biāo) END; -- 結(jié)束存儲過程
3.存儲過程的調(diào)用
#調(diào)用沒有返回值的存儲過程CALL 存儲過程名(參數(shù).....); #調(diào)用有返回值的存儲過程(獲得返回值) CALL 存儲過程名(@aaa); SELECT @aaa;
4.刪除存儲過程
DROP PROCEDURE 存儲過程名;
5.注意事項(xiàng)
存儲過程中的分號(;)很重要,盡量不要省略。
您可能感興趣的文章:
- 深入了解Mysql邏輯架構(gòu)
- MySQL高級學(xué)習(xí)筆記(三):Mysql邏輯架構(gòu)介紹、mysql存儲引擎詳解
- 詳解MySQL執(zhí)行原理、邏輯分層、更改數(shù)據(jù)庫處理引擎
- Mysql邏輯架構(gòu)詳解
- 關(guān)于避免MySQL替換邏輯SQL的坑爹操作詳解
- 利用PHP訪問MySql數(shù)據(jù)庫的邏輯操作以及增刪改查的實(shí)例講解
- MySql存儲過程之邏輯判斷和條件控制
- MySQL 利用frm文件和ibd文件恢復(fù)表數(shù)據(jù)
- MySQL使用binlog日志做數(shù)據(jù)恢復(fù)的實(shí)現(xiàn)
- MySQL 基于時(shí)間點(diǎn)的快速恢復(fù)方案
- MySQL5.7 mysqldump備份與恢復(fù)的實(shí)現(xiàn)
- MySQL 邏輯備份與恢復(fù)測試的相關(guān)總結(jié)
相關(guān)文章
Ubuntu 20.04 安裝和配置MySql5.7的詳細(xì)教程
這篇文章主要介紹了Ubuntu 20.04 安裝和配置MySql5.7的相關(guān)資料,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12Mysql計(jì)算n日留存率的實(shí)現(xiàn)
本文主要介紹了Mysql計(jì)算n日留存率的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01