日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SQL中的游標、異常處理、存儲函數及總結(最新推薦)

瀏覽:307日期:2023-03-06 14:25:45
目錄
  • 一.游標
    • 格式
    • 操作
    • 演示
  • 二.異常處理—handler句柄
    • 格式
    • 演示
  • 三.存儲函數
    • 格式
    • 參數說明
    • 演示
  • 四.存儲過程總結

    一.游標

    游標(cursor)是用來存儲查詢結果集的數據類型,在存儲過程和函數中可以使用游標對結果集進行循環的處理。游標的使用包括游標的聲明、OPEN、FETCH和 CLOSE.

    格式

    操作

    演示

    use test_procedure ;-- 需求:輸入一個部門名,查詢該部門員工的編號、名字、薪資,將查詢的結果集添加游標delimiter $$create procedure proc21(in in_name varchar(50))begin	-- 定義局部變量	declare var_empno int;	declare var_ename varchar(50);	declare var_sal decimal(7,2);	-- 聲明游標	declare my_cursor cursor for	select empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;	-- 打開游標	open my_cursor;	-- 通過游標獲得值	fetch my_cursor into var_empno,var_ename,var_sal;	select var_empno,var_ename,var_sal;	-- 關閉游標	close my_cursor;end $$delimiter ; call proc21("銷售部");

    運行輸出的結果是

    但是

    我們發現符合要求的有多個值,這是因為游標是一條條往下執行的所以我們可以用一個循環

    use test_procedure ;-- 需求:輸入一個部門名,查詢該部門員工的編號、名字、薪資,將查詢的結果集添加游標delimiter $$create procedure proc21(in in_name varchar(50))begin	-- 定義局部變量	declare var_empno int;	declare var_ename varchar(50);	declare var_sal decimal(7,2);	-- 聲明游標	declare my_cursor cursor for	select empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;	-- 打開游標	open my_cursor;	-- 通過游標獲得值	label:loop	fetch my_cursor into var_empno,var_ename,var_sal;	select var_empno,var_ename,var_sal;	end loop label;	-- 關閉游標	close my_cursor;end $$delimiter ; call proc21("銷售部");

    結果會報錯

    No data - zero rows fetched, selected, or processed 這句話意思是沒有數據 零行 讀取 選擇或處理,就是說循環到最后沒值了,所以我們需要找到一個條件并及時退出循環,這就需要異常處理—handler句柄。

    二.異常處理—handler句柄

    格式

    注意

    在語法中,變量聲明、游標聲明、handler聲明是必須按照先后順序書寫的,否則創建存儲過程出錯。

    --定義句柄:定義異常的處理方式

    1:異常處理完之后程序該怎么執行
    continue :繼續執行剩余代碼

    exit :直接終止程序
    undo:不支持
    2:觸發條件

    條件碼:1329

    條件名:
    SQLWARNING

    NOT FOUND

    SQLEXCEPTION

    演示

    -- 用條件名use test_procedure ;-- 需求:輸入一個部門名,查詢該部門員工的編號、名字、薪資,將查詢的結果集添加游標delimiter $$create procedure proc22(in in_name varchar(50))begin	-- 定義局部變量	declare var_empno int;	declare var_ename varchar(50);	declare var_sal decimal(7,2); 	-- 定義標記值	declare flag int default 1;	-- 聲明游標	declare my_cursor cursor for	select empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;	-- 定義句柄,當數據未發現時將標記位設置為0	declare continue handler for  not found set flag=0; 	-- 打開游標	open my_cursor;	-- 通過游標獲得值	label:loop	fetch my_cursor into var_empno,var_ename,var_sal;	if flag=1 then		select var_empno,var_ename,var_sal;	else		leave label;	end if;	end loop label;	-- 關閉游標	close my_cursor;end $$delimiter ; call proc22("銷售部");   -- 用條件碼use test_procedure ;-- 需求:輸入一個部門名,查詢該部門員工的編號、名字、薪資,將查詢的結果集添加游標delimiter $$create procedure proc23(in in_name varchar(50))begin	-- 定義局部變量	declare var_empno int;	declare var_ename varchar(50);	declare var_sal decimal(7,2); 	-- 定義標記值	declare flag int default 1;	-- 聲明游標	declare my_cursor cursor for	select empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;	-- 定義句柄,當數據未發現時將標記位設置為0	declare continue handler for  1329 set flag=0; 	-- 打開游標	open my_cursor;	-- 通過游標獲得值	label:loop	fetch my_cursor into var_empno,var_ename,var_sal;	if flag=1 then		select var_empno,var_ename,var_sal;	else		leave label;	end if;	end loop label;	-- 關閉游標	close my_cursor;end $$delimiter ; call proc23("銷售部");

    兩個的運行結果是一樣的

    三.存儲函數

    格式

    在MySQL中,創建存儲函數使用create function關鍵字,其基本形式如下:

    參數說明

    (1) func_name :存儲函數的名稱。
    (2) param_name type:可選項,指定存儲函數的參數。type參數用于指定存儲函數的參數類型,該類型可以是MySQL數據庫中所有支持的類型。
    (3)returns type:指定返回值的類型。
    (4)characteristic:可選項,指定存儲函數的特性。
    (5)routine_body: SQL代碼內容。

    演示

    drop function if exists myfunc1_emp;delimiter $$create function myfunc1_emp() returns intbegin	declare cnt int default 0;	select count(*) into cnt from emp;	return cnt;end $$delimiter ;

    運行結果可以會報錯,像這樣

    意思是說“此函數在其聲明中沒有確定性、無 SQL 或讀取 SQL 數據,并且啟用了二進制日志記錄(您*可能*希望使用不太安全的 log_bin_trust_function_creators 變量)”

    所以我們設置允許創建函數權限信任即可

    -- 允許創建函數權限信任
    set global log_bin_trust_function_creators=true ;

    -- 允許創建函數權限信任set global log_bin_trust_function_creators=true ; drop function if exists myfunc1_emp;delimiter $$create function myfunc1_emp() returns intbegin	declare cnt int default 0;	select count(*) into cnt from emp;	return cnt;end $$delimiter ; -- 調用存儲函數select myfunc1_emp();

    這樣就可以了

    四.存儲過程總結

    到此這篇關于SQL中的游標、異常處理、存儲函數及總結的文章就介紹到這了,更多相關SQL中的游標、異常處理、存儲函數內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

    標簽: MsSQL
    日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
    91精品在线免费视频| 久久三级视频| 免费日韩av片| 欧美精品二区| 亚洲少妇在线| 久久久影院免费| 色综合五月天| 精品视频91| 免费观看在线综合| 午夜精品成人av| 国产精品一级| 亚洲高清影视| 久久久久九九精品影院| 蜜臀91精品国产高清在线观看| 日韩久久精品| 麻豆成人91精品二区三区| 亚洲精品系列| 亚洲一区二区av| 日韩美女一区二区三区在线观看| 国产精品九九| 开心激情综合| 伊人网在线播放| 岛国av在线播放| 91精品国产乱码久久久久久久| 亚洲福利精品| 日韩精品导航| 久久99蜜桃| 国产亚洲精品美女久久| 国产精品一页| 国产日韩一区| 日韩毛片视频| 老牛国产精品一区的观看方式| 亚洲人妖在线| 国产探花在线精品一区二区| 国产黄色精品| av在线日韩| 亚洲不卡视频| 精品视频97| 日韩视频不卡| 欧美交a欧美精品喷水| 一区视频在线| 国产欧美日韩精品高清二区综合区 | 久久久精品区| 欧美成人久久| 91成人在线| 亚洲在线国产日韩欧美| 久久黄色影视| 久久中文字幕二区| 国产一精品一av一免费爽爽| 香蕉成人久久| 日韩理论视频| 麻豆精品视频在线观看视频| 久久精品国产68国产精品亚洲| 图片区亚洲欧美小说区| 国产伦理一区| 久久亚洲风情| 99久久99视频只有精品| 日本va欧美va瓶| 一区二区自拍| 日韩av首页| 精品三级av在线导航| 在线精品小视频| 一区二区精品伦理...| 国产精品极品| 精品国产精品久久一区免费式| 一区二区日韩免费看| 黄色亚洲大片免费在线观看| 久久精品网址| 国产精品丝袜在线播放| 日日摸夜夜添夜夜添国产精品| 极品日韩av| 在线精品小视频| 欧美天堂亚洲电影院在线观看| 日韩欧美一区二区三区在线视频 | 精品国产aⅴ| 日韩福利视频一区| 日韩毛片一区| 日本中文字幕不卡| 美国三级日本三级久久99| 亚洲欧美激情诱惑| 免费在线观看一区二区三区| 一本色道精品久久一区二区三区| 999视频精品| 99riav1国产精品视频| 激情婷婷综合| 蜜臀久久99精品久久久画质超高清| 亚洲一区激情| 少妇高潮一区二区三区99| 日韩精品第一| 国产伦精品一区二区三区千人斩| 欧美日本精品| 国产成人精品一区二区三区免费| 欧美sm一区| 国产极品模特精品一二| 麻豆精品新av中文字幕| 日本韩国欧美超级黄在线观看| 亚洲激情黄色| 国产精品nxnn| 免费精品国产| 久久国内精品自在自线400部| 日韩一区亚洲二区| 男人操女人的视频在线观看欧美| 伊人国产精品| 蜜臀久久精品| 日韩一级欧洲| 久久精品国产福利| 夜夜嗨一区二区| 国产精品一区毛片| 国产精品久久久久久久久免费高清| 丰满少妇一区| 免播放器亚洲一区| 日本久久精品| 日产精品一区二区| 在线亚洲观看| 国产成年精品| 亚州精品视频| 欧美日韩日本国产亚洲在线 | 久久久久久久欧美精品| 亚洲婷婷免费| 丁香婷婷久久| 97精品国产99久久久久久免费| 久久久夜夜夜| 欧美国产一级| 国产精品99一区二区三| 18国产精品| 日本不卡视频在线观看| 丝袜美腿亚洲色图| 在线一区视频| 中文字幕人成乱码在线观看 | 欧美freesex黑人又粗又大| 毛片不卡一区二区| 国产精品视频一区二区三区四蜜臂 | 国产精品黑丝在线播放| 久久天堂成人| 欧洲精品一区二区三区| 日韩在线二区| 亚洲特级毛片| 伊人影院久久| 免费人成网站在线观看欧美高清| 久久国产电影| 国产视频欧美| 丝袜亚洲精品中文字幕一区| 亚洲欧美日本日韩| 日本h片久久| 麻豆久久一区二区| 国产高清精品二区| 国产精品日本一区二区不卡视频| 国产日本久久| 国产精品伦一区二区| 国产日韩亚洲欧美精品| 日本久久二区| 精品久久97| 成人福利av| 免费看av不卡| 蜜臀av一区二区三区| 日韩国产高清在线| 国产一区二区三区成人欧美日韩在线观看 | 亚洲精品高潮| 久久一区欧美| 久久激情婷婷| 好吊日精品视频 | 久久久精品五月天| 蜜桃视频在线观看一区二区| 国产精品一区二区av交换 | 国产精品成人自拍| 久久久久久久久99精品大| 美日韩精品视频| 精品久久亚洲| 综合五月婷婷| 色欧美自拍视频| 美女黄网久久| 国产劲爆久久| 国产精品7m凸凹视频分类| 日本免费在线视频不卡一不卡二| 国内不卡的一区二区三区中文字幕| 欧美特黄a级高清免费大片a级| 最新亚洲国产| 乱人伦精品视频在线观看| 国产一区调教| 老司机精品久久| 日韩欧美一区二区三区免费观看| 久久av在线| 精品国产亚洲一区二区三区大结局| 欧洲激情综合| 肉色欧美久久久久久久免费看| 国产精品尤物| 欧美在线观看天堂一区二区三区| 91亚洲国产| 国产精品久久亚洲不卡| 色8久久久久| 男人操女人的视频在线观看欧美| 国内精品福利| 精品亚洲a∨一区二区三区18| 久久99久久久精品欧美| 91成人小视频| 亚洲图片久久| 亚洲欧美网站在线观看| 欧美1区免费| 日韩精品午夜| 国产高清一区二区|