mysql游標的原理與用法實例分析
本文實例講述了mysql游標的原理與用法。分享給大家供大家參考,具體如下:
本文內(nèi)容: 什么是游標 創(chuàng)建游標 使用游標首發(fā)日期:2018-04-18
什么是游標: 如果你前面看過mysql函數(shù),會發(fā)現(xiàn)無法使用返回多行結(jié)果的語句。但如果你又確實想要使用時,就需要使用到游標,游標可以幫你選擇出某個結(jié)果(這樣就可以做到返回單個結(jié)果)。 另外,使用游標也可以輕易的取出在檢索出來的行中前進或后退一行或多行的結(jié)果。 游標可以遍歷返回的多行結(jié)果。補充: Mysql中游標只適用于存儲過程以及函數(shù)。創(chuàng)建游標: 語法: 1.定義游標:declare 游標名 cursor for select語句; 2.打開游標:open 游標名; 獲取結(jié)果:fetch 游標名 into 變量名[,變量名]; 關(guān)閉游標:close 游標名;create procedure p1()begin declare id int; declare name varchar(15); -- 聲明游標 declare mc cursor for select * from class; -- 打開游標 open mc; -- 獲取結(jié)果 fetch mc into id,name; -- 這里是為了顯示獲取結(jié)果 select id,name; -- 關(guān)閉游標 close mc; end;
create procedure p2()begin declare id int; declare name varchar(15); -- 聲明游標 declare mc cursor for select * from class; -- 打開游標 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)閉游標 end loop; close mc; end;使用游標: 游標每一次fetch都是獲取一行結(jié)果,可以使用變量來獲取fetch到的每一列的值
create procedure p2()begin declare id int; declare name varchar(15); -- 聲明游標 declare mc cursor for select * from class; -- 打開游標 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)閉游標 end loop; close mc; end;
上面的代碼會有一個報錯
,不斷循環(huán)的話,始終會達到表的末尾,到了末尾就無法繼續(xù)fetch,一般來說都要避免報錯,到了末尾前會有一個mysql定義的
create procedure p3()begin declare id int; declare name varchar(15); declare flag int default 0; -- 聲明游標 declare mc cursor for select * from class; declare continue handler for not found set flag = 1; -- 打開游標 open mc; -- 獲取結(jié)果 l2:loop fetch mc into id,name; if flag=1 then -- 當(dāng)無法fetch會觸發(fā)handler continue leave l2; end if; -- 這里是為了顯示獲取結(jié)果 insert into class2 values(id,name); -- 關(guān)閉游標 end loop; close mc; end;call p3();-- 不報錯select * from class2;
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。
相關(guān)文章:
1. Access數(shù)據(jù)庫安全的幾個問題2. Windwos下MySQL 64位壓縮包的安裝方法學(xué)習(xí)記錄3. mysql-bin.000001文件的來源及處理方法4. mysql啟動時報錯 ERROR! Manager of pid-file quit without5. ACCESS轉(zhuǎn)SQL數(shù)據(jù)庫相關(guān)的幾個技能6. 數(shù)據(jù)庫相關(guān)的幾個技能:ACCESS轉(zhuǎn)SQL8. mysql命令行客戶端結(jié)果分頁瀏覽9. 什么是Access數(shù)據(jù)庫10. Oracle聯(lián)機日志文件與歸檔文件詳細介紹

網(wǎng)公網(wǎng)安備