www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

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

mysql的存儲過程可以很方便使用游標(biāo)來實現(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
	--?聲明一個標(biāo)志done,?用來判斷游標(biāo)是否遍歷完成
	DECLARE?done?INT?DEFAULT?0;

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

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

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

	--?執(zhí)行查詢
	open?cur;
	--?遍歷游標(biāo)每一行
	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();

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

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();

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

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)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉