女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

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

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

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

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;

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

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

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

	--?執(zhí)行查詢
	open?cur;
	--?遍歷游標每一行
	REPEAT
		--?把一行的信息存放在對應的變量中
		FETCH?cur?INTO?tname,?tpass;
		if?not?done?then
			--?這里就可以使用?tname,?tpass?對應的信息了
			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,因為當第一個游標遍歷玩后其值被handler設置為1了,如果不用set把它設置為 0 ,那么第二個游標就不會遍歷了。當然好習慣是在每個打開游標的操作前都用該語句,確保游標能真正遍歷。當然還可以使用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();


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

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

關鍵字: 驅動電源

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

關鍵字: 工業(yè)電機 驅動電源

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

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

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

關鍵字: 電動汽車 新能源 驅動電源

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

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

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

關鍵字: LED 驅動電源 功率因數校正

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

關鍵字: LED照明技術 電磁干擾 驅動電源

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

關鍵字: LED 驅動電源 開關電源

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

關鍵字: LED 隧道燈 驅動電源
關閉