當前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]mysql的存儲過程可以很方便使用游標來實現(xiàn)一些功能,存儲過程的寫法大致如下:先創(chuàng)建一張表,插入一些測試數(shù)據(jù):DROP?TABLE?IF?EXISTS?netingcn_proc_test; CRE

mysql的存儲過程可以很方便使用游標來實現(xiàn)一些功能,存儲過程的寫法大致如下:

先創(chuàng)建一張表,插入一些測試數(shù)據(jù):

DROP?TABLE?IF?EXISTS?netingcn_proc_test;

CREATE?TABLE?`netingcn_proc_test`?(
??`id`?INTEGER(11)?NOT?NULL?AUTO_INCREMENT,
??`name`?VARCHAR(20),
??`password`?VARCHAR(20),
??PRIMARY?KEY?(`id`)
)ENGINE=InnoDB;

insert?into?netingcn_proc_test(name,?password)?values
('procedure1',?'pass1'),
('procedure2',?'pass2'),
('procedure3',?'pass3'),
('procedure4',?'pass4');

下面就是一個簡單存儲過程的例子:

drop?procedure?IF?EXISTS?test_proc;
delimiter?//
create?procedure?test_proc()
begin
	--?聲明一個標志done,?用來判斷游標是否遍歷完成
	DECLARE?done?INT?DEFAULT?0;

	--?聲明一個變量,用來存放從游標中提取的數(shù)據(jù)
	--?特別注意這里的名字不能與由游標中使用的列明相同,否則得到的數(shù)據(jù)都是NULL
	DECLARE?tname?varchar(50)?DEFAULT?NULL;
	DECLARE?tpass?varchar(50)?DEFAULT?NULL;

	--?聲明游標對應(yīng)的?SQL?語句
	DECLARE?cur?CURSOR?FOR
		select?name,?password?from?netingcn_proc_test;

	--?在游標循環(huán)到最后會將?done?設(shè)置為?1
	DECLARE?CONTINUE?HANDLER?FOR?NOT?FOUND?SET?done?=?1;

	--?執(zhí)行查詢
	open?cur;
	--?遍歷游標每一行
	REPEAT
		--?把一行的信息存放在對應(yīng)的變量中
		FETCH?cur?INTO?tname,?tpass;
		if?not?done?then
			--?這里就可以使用?tname,?tpass?對應(yīng)的信息了
			select?tname,?tpass;
		end?if;
?	UNTIL?done?END?REPEAT;
	CLOSE?cur;
end
//
delimiter?;

--?執(zhí)行存儲過程
call?test_proc();

需要注意的是變量的聲明、游標的聲明和HANDLER聲明的順序不能搞錯,必須是先聲明變量,再申明游標,最后聲明HANDLER。上述存儲過程的例子中只使用了一個游標,那么如果要使用兩個或者更多游標怎么辦,其實很簡單,可以這么說,一個怎么用兩個就是怎么用的。例子如下:

drop?procedure?IF?EXISTS?test_proc_1;
delimiter?//
create?procedure?test_proc_1()
begin
	DECLARE?done?INT?DEFAULT?0;
	DECLARE?tid?int(11)?DEFAULT?0;
	DECLARE?tname?varchar(50)?DEFAULT?NULL;
	DECLARE?tpass?varchar(50)?DEFAULT?NULL;

	DECLARE?cur_1?CURSOR?FOR
		select?name,?password?from?netingcn_proc_test;

	DECLARE?cur_2?CURSOR?FOR
		select?id,?name?from?netingcn_proc_test;

	DECLARE?CONTINUE?HANDLER?FOR?NOT?FOUND?SET?done?=?1;

	open?cur_1;
	REPEAT
		FETCH?cur_1?INTO?tname,?tpass;
		if?not?done?then
			select?tname,?tpass;
		end?if;
?	UNTIL?done?END?REPEAT;
	CLOSE?cur_1;

	--?注意這里,一定要重置done的值為?0
	set?done?=?0;

	open?cur_2;
	REPEAT
		FETCH?cur_2?INTO?tid,?tname;
		if?not?done?then
			select?tid,?tname;
		end?if;
?	UNTIL?done?END?REPEAT;
	CLOSE?cur_2;
end
//
delimiter?;

call?test_proc_1();

上述代碼和第一個例子中基本一樣,就是多了一個游標聲明和遍歷游標。這里需要注意的是,在遍歷第二個游標前使用了set done = 0,因為當?shù)谝粋€游標遍歷玩后其值被handler設(shè)置為1了,如果不用set把它設(shè)置為 0 ,那么第二個游標就不會遍歷了。當然好習(xí)慣是在每個打開游標的操作前都用該語句,確保游標能真正遍歷。當然還可以使用begin語句塊嵌套的方式來處理多個游標,例如:

drop?procedure?IF?EXISTS?test_proc_2;
delimiter?//
create?procedure?test_proc_2()
begin
	DECLARE?done?INT?DEFAULT?0;
	DECLARE?tname?varchar(50)?DEFAULT?NULL;
	DECLARE?tpass?varchar(50)?DEFAULT?NULL;

	DECLARE?cur_1?CURSOR?FOR
		select?name,?password?from?netingcn_proc_test;

	DECLARE?cur_2?CURSOR?FOR
		select?id,?name?from?netingcn_proc_test;

	DECLARE?CONTINUE?HANDLER?FOR?NOT?FOUND?SET?done?=?1;

	open?cur_1;
	REPEAT
		FETCH?cur_1?INTO?tname,?tpass;
		if?not?done?then
			select?tname,?tpass;
		end?if;
?	UNTIL?done?END?REPEAT;
	CLOSE?cur_1;

	begin
		DECLARE?done?INT?DEFAULT?0;
		DECLARE?tid?int(11)?DEFAULT?0;
		DECLARE?tname?varchar(50)?DEFAULT?NULL;

		DECLARE?cur_2?CURSOR?FOR
			select?id,?name?from?netingcn_proc_test;

		DECLARE?CONTINUE?HANDLER?FOR?NOT?FOUND?SET?done?=?1;

		open?cur_2;
		REPEAT
			FETCH?cur_2?INTO?tid,?tname;
			if?not?done?then
				select?tid,?tname;
			end?if;
	?	UNTIL?done?END?REPEAT;
		CLOSE?cur_2;
	end;
end
//
delimiter?;

call?test_proc_2();


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉