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