mysql游標的原理與用法實例分析
更新時間:2020年04月10日 10:37:48 作者:隨風行云
這篇文章主要介紹了mysql游標的原理與用法,結合實例形式分析了mysql游標的概念、原理、用法及操作注意事項,需要的朋友可以參考下
本文實例講述了mysql游標的原理與用法。分享給大家供大家參考,具體如下:
本文內容:
- 什么是游標
- 創(chuàng)建游標
- 使用游標
首發(fā)日期:2018-04-18
什么是游標:
- 如果你前面看過mysql函數,會發(fā)現無法使用返回多行結果的語句。但如果你又確實想要使用時,就需要使用到游標,游標可以幫你選擇出某個結果(這樣就可以做到返回單個結果)。
- 另外,使用游標也可以輕易的取出在檢索出來的行中前進或后退一行或多行的結果。
- 游標可以遍歷返回的多行結果。
補充:
- Mysql中游標只適用于存儲過程以及函數。
創(chuàng)建游標:
- 語法:
- 1.定義游標:declare 游標名 cursor for select語句;
- 2.打開游標:open 游標名;
- 獲取結果:fetch 游標名 into 變量名[,變量名];
- 關閉游標:close 游標名;
create procedure p1() begin declare id int; declare name varchar(15); -- 聲明游標 declare mc cursor for select * from class; -- 打開游標 open mc; -- 獲取結果 fetch mc into id,name; -- 這里是為了顯示獲取結果 select id,name; -- 關閉游標 close mc; end;
create procedure p2() begin declare id int; declare name varchar(15); -- 聲明游標 declare mc cursor for select * from class; -- 打開游標 open mc; -- 獲取結果 loop -- 循環(huán),將表的內容都轉移到class2中 fetch mc into id,name; -- 這里是為了顯示獲取結果 insert into class2 values(id,name); -- 關閉游標 end loop; close mc; end;
使用游標:
- 游標每一次fetch都是獲取一行結果,可以使用變量來獲取fetch到的每一列的值
create procedure p2() begin declare id int; declare name varchar(15); -- 聲明游標 declare mc cursor for select * from class; -- 打開游標 open mc; -- 獲取結果 loop -- 循環(huán),將表的內容都轉移到class2中 fetch mc into id,name; -- 這里是為了顯示獲取結果 insert into class2 values(id,name); -- 關閉游標 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; -- 獲取結果 l2:loop fetch mc into id,name; if flag=1 then -- 當無法fetch會觸發(fā)handler continue leave l2; end if; -- 這里是為了顯示獲取結果 insert into class2 values(id,name); -- 關閉游標 end loop; close mc; end; call p3();-- 不報錯 select * from class2;
更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》
希望本文所述對大家MySQL數據庫計有所幫助。
相關文章
在IDEA的maven項目中連接并使用MySQL8.0的方法教程
這篇文章主要介紹了如何在IDEA的maven項目中連接并使用MySQL8.0,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02MSQL中DATETIME或TIMESTAMP的區(qū)別小結
MySQL中的?DATETIME?和?TIMESTAMP?類型都用于存儲日期和時間信息,本文主要介紹了MSQL中DATETIME或TIMESTAMP的區(qū)別小結,具有一定的參考價值,感興趣的可以了解一下2024-03-03mysql使用教程之分區(qū)表的使用方法(刪除分區(qū)表)
mysql分區(qū)表使用方法,新增分區(qū)、刪除分區(qū)、分區(qū)的合并、分區(qū)的拆分等使用方法2013-12-12