mysql游標(biāo)的原理與用法實例分析
本文實例講述了mysql游標(biāo)的原理與用法。分享給大家供大家參考,具體如下:
本文內(nèi)容:
- 什么是游標(biāo)
- 創(chuàng)建游標(biāo)
- 使用游標(biāo)
首發(fā)日期:2018-04-18
什么是游標(biāo):
- 如果你前面看過mysql函數(shù),會發(fā)現(xiàn)無法使用返回多行結(jié)果的語句。但如果你又確實想要使用時,就需要使用到游標(biāo),游標(biāo)可以幫你選擇出某個結(jié)果(這樣就可以做到返回單個結(jié)果)。
- 另外,使用游標(biāo)也可以輕易的取出在檢索出來的行中前進(jìn)或后退一行或多行的結(jié)果。
- 游標(biāo)可以遍歷返回的多行結(jié)果。
補充:
- Mysql中游標(biāo)只適用于存儲過程以及函數(shù)。
創(chuàng)建游標(biāo):
- 語法:
- 1.定義游標(biāo):declare 游標(biāo)名 cursor for select語句;
- 2.打開游標(biāo):open 游標(biāo)名;
- 獲取結(jié)果:fetch 游標(biāo)名 into 變量名[,變量名];
- 關(guān)閉游標(biāo):close 游標(biāo)名;
create procedure p1() begin declare id int; declare name varchar(15); -- 聲明游標(biāo) declare mc cursor for select * from class; -- 打開游標(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; -- 打開游標(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;
使用游標(biāo):
- 游標(biāo)每一次fetch都是獲取一行結(jié)果,可以使用變量來獲取fetch到的每一列的值
create procedure p2() begin declare id int; declare name varchar(15); -- 聲明游標(biāo) declare mc cursor for select * from class; -- 打開游標(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án)的話,始終會達(dá)到表的末尾,到了末尾就無法繼續(xù)fetch,一般來說都要避免報錯,到了末尾前會有一個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; -- 打開游標(biāo) 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)閉游標(biāo) 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ù)庫計有所幫助。
- MySQL 游標(biāo)的定義與使用方式
- Mysql 存儲過程中使用游標(biāo)循環(huán)讀取臨時表
- mysql聲明游標(biāo)的方法
- 詳解Mysql 游標(biāo)的用法及其作用
- 帶你徹底搞懂python操作mysql數(shù)據(jù)庫(cursor游標(biāo)講解)
- mysql存儲過程之游標(biāo)(DECLARE)原理與用法詳解
- MySQL游標(biāo)概念與用法詳解
- mysql的存儲過程、游標(biāo) 、事務(wù)實例詳解
- Mysql存儲過程中游標(biāo)的用法實例
- Mysql存儲過程循環(huán)內(nèi)嵌套使用游標(biāo)示例代碼
- MySQL存儲過程中游標(biāo)循環(huán)的跳出和繼續(xù)操作示例
- MySQL 游標(biāo)的作用與使用相關(guān)
相關(guān)文章
MySQL group_concat函數(shù)使用方法詳解
GROUP_CONCAT函數(shù)用于將GROUP BY產(chǎn)生的同一個分組中的值連接起來,返回一個字符串結(jié)果,接下來就給大家簡單的介紹一下MySQL group_concat函數(shù)的使用方法,需要的朋友可以參考下2023-07-07在IDEA的maven項目中連接并使用MySQL8.0的方法教程
這篇文章主要介紹了如何在IDEA的maven項目中連接并使用MySQL8.0,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function
這篇文章主要介紹了MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-06-06textarea標(biāo)簽(存取數(shù)據(jù)庫mysql)的換行方法
textarea標(biāo)簽本身不識別換行功能,回車換行用的是\n換行符,輸入時的確有換行的效果,但是html渲染或者保存數(shù)據(jù)庫mysql時就只是一個空格了,這時就需要利用換行符\n和br標(biāo)簽的轉(zhuǎn)換進(jìn)行處理2023-09-09MSQL中DATETIME或TIMESTAMP的區(qū)別小結(jié)
MySQL中的?DATETIME?和?TIMESTAMP?類型都用于存儲日期和時間信息,本文主要介紹了MSQL中DATETIME或TIMESTAMP的區(qū)別小結(jié),具有一定的參考價值,感興趣的可以了解一下2024-03-03mysql使用教程之分區(qū)表的使用方法(刪除分區(qū)表)
mysql分區(qū)表使用方法,新增分區(qū)、刪除分區(qū)、分區(qū)的合并、分區(qū)的拆分等使用方法2013-12-12