本文實(shí)例講述了mysql游標(biāo)的原理與用法。分享給大家供大家參考,具體如下:
首發(fā)日期:2018-04-18
create procedure p1() begin declare id int; declare name varchar(15); -- 聲明游標(biāo) declare mc cursor for select * from class; -- 打開(kāi)游標(biāo) open mc; -- 獲取結(jié)果 fetch mc into id,name; -- 這里是為了顯示獲取結(jié)果 select id,name; -- 關(guān)閉游標(biāo) close mc; end;
create procedure p2() begin declare id int; declare name varchar(15); -- 聲明游標(biāo) declare mc cursor for select * from class; -- 打開(kāi)游標(biāo) open mc; -- 獲取結(jié)果 loop -- 循環(huán),將表的內(nèi)容都轉(zhuǎn)移到class2中 fetch mc into id,name; -- 這里是為了顯示獲取結(jié)果 insert into class2 values(id,name); -- 關(guān)閉游標(biāo) end loop; close mc; end;
create procedure p2() begin declare id int; declare name varchar(15); -- 聲明游標(biāo) declare mc cursor for select * from class; -- 打開(kāi)游標(biāo) open mc; -- 獲取結(jié)果 loop -- 循環(huán),將表的內(nèi)容都轉(zhuǎn)移到class2中 fetch mc into id,name; -- 這里是為了顯示獲取結(jié)果 insert into class2 values(id,name); -- 關(guān)閉游標(biāo) end loop; close mc; end;
上面的代碼會(huì)有一個(gè)報(bào)錯(cuò),不斷循環(huán)的話(huà),始終會(huì)達(dá)到表的末尾,到了末尾就無(wú)法繼續(xù)fetch,一般來(lái)說(shuō)都要避免報(bào)錯(cuò),到了末尾前會(huì)有一個(gè)mysql定義的
create procedure p3() begin declare id int; declare name varchar(15); declare flag int default 0; -- 聲明游標(biāo) declare mc cursor for select * from class; declare continue handler for not found set flag = 1; -- 打開(kāi)游標(biāo) open mc; -- 獲取結(jié)果 l2:loop fetch mc into id,name; if flag=1 then -- 當(dāng)無(wú)法fetch會(huì)觸發(fā)handler continue leave l2; end if; -- 這里是為了顯示獲取結(jié)果 insert into class2 values(id,name); -- 關(guān)閉游標(biāo) end loop; close mc; end; call p3();-- 不報(bào)錯(cuò) select * from class2;
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《MySQL查詢(xún)技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過(guò)程技巧大全》、《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總》
希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。
標(biāo)簽:寧夏 澳門(mén) 益陽(yáng) 杭州 恩施 秦皇島 定西 白銀
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mysql游標(biāo)的原理與用法實(shí)例分析》,本文關(guān)鍵詞 mysql,游,標(biāo)的,原理,與,用法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。