婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL游標概念與用法詳解

MySQL游標概念與用法詳解

熱門標簽:400電話申請廠家現貨 中國地圖標注公司 天津公司外呼系統軟件 百度地圖標注要什么軟件 福建外呼電銷機器人加盟 昌德訊外呼系統 自己做地圖標注需要些什么 電話機器人的價格多少錢一個月 徐涇鎮騰訊地圖標注

本文實例講述了MySQL游標概念與用法。分享給大家供大家參考,具體如下:

1、游標的概念(Cursor)

一條sql,對應N條資源,取出資源的接口,就是游標,沿著游標,可以一次取出1行。如果開發過安卓的同學應該知道有一個Api是Cursor,也是讀取SQLite數據庫用的,和這個有點類似。

2、使用游標的步驟

(1)聲明

使用declare進行聲明

declare 游標名 cursor for select_statement

(2)打開游標

使用open進行打開

open 游標名

(3)從游標中取值

使用fetch進行取值

fetch 游標名 into var1,var2[,...] --將取到的一行賦值給多個變量

(4)關閉游標

使用close關閉游標

close 游標名

3、創建一個簡單的游標

需求:從商品表中讀取第一行數據

商品表(goods)數據:

注意:我這里已經將MySQL的結束標識符改為 $,如果要知道怎么設置為$,請參考前面一篇文章:MySQL觸發器。

定義:

create procedure p12()
begin
  /*定義三個變量用于存放商品id,商品名稱,商品庫存量*/
  declare row_gid int ; 
  declare row_name varchar(20);
  declare row_num int;
  declare getgoods cursor for select gid,name,num from goods;  --定義游標
  open getgoods; --打開游標
  fetch getgoods into row_gid,row_name,row_num;--從游標中取值
  select row_name,row_num; --顯示操作
  close getgoods; --關閉游標
end$

輸出結果:

4、多次取值操作

create procedure p13()
begin
  declare row_gid int ;
  declare row_name varchar(20);
  declare row_num int;
  declare getgoods cursor for select gid,name,num from goods;  
  open getgoods;
  fetch getgoods into row_gid,row_name,row_num;
  select row_name,row_num;
  fetch getgoods into row_gid,row_name,row_num;
  select row_name,row_num;
  fetch getgoods into row_gid,row_name,row_num;
  select row_name,row_num;
  fetch getgoods into row_gid,row_name,row_num;
  select row_name,row_num;
  close getgoods;
end$

輸出:

注意:當游標讀到末尾,如果繼續進行取值操作會發生報錯

5、游標循環表中的所有數據

(1)使用計數器來循環

create procedure p14()
begin 
  declare cnt int default 0;
  declare i int default 0;
  declare row_gid int ;
  declare row_name varchar(20);
  declare row_num int;
  declare getgoods cursor for select gid,name,num from goods;
  select count(*) into cnt from goods;
  open getgoods;
  repeat 
    fetch getgoods into row_gid,row_name,row_num;
  select row_name,row_num;
  set i:= i+1;
  until i >= cnt end repeat;
  close getgoods;
end$

輸出結果:

(2)使用越界標志來控制循環

在mysql cursor中,可以聲明declare continue handler來操作1個越界標志

語法:

declare continue handler for NOT FOUND statement;

使用:

create procedure p15()
begin
  declare row_gid int ;
  declare row_name varchar(20);
  declare row_num int;
  declare have int default 1;
  declare getgoods cursor for select gid,name,num from goods;
  declare continue handler for NOT FOUND set have:= 0;
  open getgoods;
  repeat 
    fetch getgoods into row_gid,row_name,row_num;
  select row_name,row_num;
  until have = 0 end repeat;
  close getgoods;
end$

輸出結果:

注意:這里發生了錯誤,這里輸出了4行數據,而表中只有3行數據,而且還爆出了警告,后面會說怎么結果這個問題。

程序執行邏輯:

循環游標->fetch第三條數據->顯示->fetch第四條數據->沒有數據->設置have=0操作->執行continue Handler->程序不退出,執行顯示操作->還是顯示第三條數據

6、continue和exit的區別

continue:若沒有數據返回,程序繼續,并將變量IS_FOUND設為0,這種情況是出現在select XX into XXX from tablename的時候發生的。
exit:若沒有數據返回,退出程序,并將變量IS_FOUND設為0,這種情況是出現在select XX into XXX from tablename的時候發生的。

使用exit來替換continue:
使用exit就不會出現上面的那種情況了,程序執行邏輯:

循環游標->fetch到第三條數據->顯示->第四次fetch操作->沒有數據->設置 have=0操作->程序直接退出exit

所以就沒有顯示出第四條數據。

create procedure p16()
begin
  declare row_gid int ;
  declare row_name varchar(20);
  declare row_num int;
  declare have int default 1;
  declare getgoods cursor for select gid,name,num from goods;
  declare exit handler for NOT FOUND set have:= 0;
  open getgoods;
  repeat 
    fetch getgoods into row_gid,row_name,row_num;
  select row_name,row_num;
  until have = 0 end repeat;
  close getgoods;
end$

輸出結果:

7、正確的游標循環

在一些特殊的情況中,我們可以讀到的數據為空,或者壓根sql語句就有錯誤,我們不能避免出現這種情況,所以我們要正確的使用游標循環操作。

首先應該創建游標,然后打開游標后,應先手動進行fetch操作獲取到一行數據,然后再通過循環,在循環里先做處理內容,后進行fetch操作。這樣如果在手動獲取數據的期間就沒有獲得到數據的話,就會執行have = 0,如果是repeat循環,然后進入repeat循環,先輸出null數據,最后又進行獲取,這樣運行到until時就會退出循環;如果是while循環,壓根就不進去while循環里,就不會有任何1行輸出。

(1)repeat循環:

create procedure p17()
begin
  declare row_gid int;
  declare row_name varchar(20);
  declare row_num int;
  declare have int default 1;
  declare getgoods cursor for select gid,name,num from goods where 0;
  declare continue handler for NOT FOUND set have:= 0;
  open getgoods;
  fetch getgoods into row_gid,row_name,row_num;
  repeat 
  select row_name,row_num;
    fetch getgoods into row_gid,row_name,row_num;
  until have = 0 end repeat;
  close getgoods;
end$

輸出結果:

(2)while循環:

create procedure p18()
begin
  declare row_gid int;
  declare row_name varchar(20);
  declare row_num int;
  declare have int default 1;
  declare getgoods cursor for select gid,name,num from goods where 0;
  declare continue handler for NOT FOUND set have:= 0;
  open getgoods;
  fetch getgoods into row_gid,row_name,row_num;
  while have = 1 do 
  select row_name,row_num;
    fetch getgoods into row_gid,row_name,row_num;
  end while;
  close getgoods;
end$

輸出結果:

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

您可能感興趣的文章:
  • MySQL 游標的定義與使用方式
  • Mysql 存儲過程中使用游標循環讀取臨時表
  • mysql聲明游標的方法
  • 詳解Mysql 游標的用法及其作用
  • mysql游標的原理與用法實例分析
  • 帶你徹底搞懂python操作mysql數據庫(cursor游標講解)
  • mysql存儲過程之游標(DECLARE)原理與用法詳解
  • mysql的存儲過程、游標 、事務實例詳解
  • Mysql存儲過程中游標的用法實例
  • Mysql存儲過程循環內嵌套使用游標示例代碼
  • MySQL存儲過程中游標循環的跳出和繼續操作示例
  • MySQL 游標的作用與使用相關

標簽:駐馬店 北京 黔西 梅河口 鄂爾多斯 荊門 昌都 陜西

巨人網絡通訊聲明:本文標題《MySQL游標概念與用法詳解》,本文關鍵詞  MySQL,游標,概念,與,用法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL游標概念與用法詳解》相關的同類信息!
  • 本頁收集關于MySQL游標概念與用法詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产一二三精品| 欧美性一级生活| 欧美成人a∨高清免费观看| 亚洲综合在线电影| 国产91丝袜在线18| 国产女主播视频一区二区| 美女一区二区在线观看| 欧美精品日韩精品| 蜜桃免费网站一区二区三区| 日韩欧美综合一区| 精品一区二区综合| 久久久夜色精品亚洲| 韩国精品久久久| 亚洲丝袜自拍清纯另类| 97se亚洲国产综合在线| 亚洲视频狠狠干| 日本韩国精品在线| 偷窥少妇高潮呻吟av久久免费| 欧美日韩久久不卡| 精品一二三四在线| 亚洲精选在线视频| 精品国产一区二区三区忘忧草 | 欧美日韩国产精品成人| 日产国产欧美视频一区精品| 亚洲精品一区二区在线观看| 不卡一区二区三区四区| 亚洲成人在线免费| 亚洲国产一区二区视频| 国产日韩欧美电影| 56国语精品自产拍在线观看| 粉嫩绯色av一区二区在线观看| 日韩美女视频一区| 国产日韩精品一区| 日韩一级免费一区| 在线这里只有精品| 国产福利视频一区二区三区| 日韩av一区二区三区| 亚洲精品日韩一| 一区二区三区欧美日| 成人小视频免费观看| 亚洲成人av一区二区三区| 日韩毛片精品高清免费| 26uuu亚洲综合色| 日韩欧美亚洲国产另类| 欧美人与禽zozo性伦| 欧美日韩电影在线播放| 日本韩国精品在线| 欧美色综合网站| 欧美午夜精品一区二区三区| 色综合一区二区三区| 欧美日韩综合在线| 日韩免费视频一区| 国产精品青草久久| 亚洲综合色在线| 91丨九色丨尤物| 国产suv精品一区二区6| 丝袜美腿一区二区三区| 亚洲成人免费看| 韩国理伦片一区二区三区在线播放| 九九国产精品视频| 国产成人综合网| 欧美日韩一区二区三区四区五区 | 五月激情六月综合| 国产自产v一区二区三区c| 国产乱人伦精品一区二区在线观看| 国产白丝网站精品污在线入口| 91女厕偷拍女厕偷拍高清| 91免费看片在线观看| 欧美日韩一区二区在线观看视频| 欧美日本在线视频| 国产精品日韩精品欧美在线| 日韩av电影天堂| 91成人在线精品| 亚洲黄色录像片| 懂色av一区二区三区免费观看| 日韩视频免费观看高清完整版 | 7777精品伊人久久久大香线蕉的 | 欧美一区二区日韩一区二区| 中文字幕免费在线观看视频一区| 日韩国产在线观看一区| www.av亚洲| 欧美欧美午夜aⅴ在线观看| 国产精品久久久久婷婷二区次| 樱桃视频在线观看一区| 99久久综合色| 国产欧美一区在线| 国产麻豆成人精品| 久久久www成人免费毛片麻豆| 日本视频免费一区| 日韩女优av电影在线观看| 美洲天堂一区二卡三卡四卡视频| 欧美精品xxxxbbbb| 日本不卡123| 免费在线一区观看| 欧美午夜片在线看| 国产精品伊人色| 国产精品不卡视频| 欧美精品自拍偷拍| 国产精品亚洲一区二区三区在线 | 国产精品久久久久久久久快鸭| 在线视频国内一区二区| 久久激五月天综合精品| 国产女主播一区| 欧美精品久久久久久久久老牛影院| 五月天激情综合| 国产亚洲成av人在线观看导航| 国产精品1024| 色综合久久久久久久久久久| 久久99久久精品| 亚洲成人自拍一区| 国产精品国产自产拍高清av王其 | 日韩精品一区二区三区视频| 91麻豆自制传媒国产之光| 狠狠色丁香久久婷婷综合丁香| 亚洲综合av网| 国产精品久久久一本精品| 日韩欧美电影一二三| 在线观看一区不卡| 成人高清免费在线播放| 精品一区中文字幕| 亚洲欧美aⅴ...| 亚洲成人777| 精品久久久久av影院 | 在线免费精品视频| 中文字幕一区二区三区不卡| 91麻豆精品国产91久久久资源速度 | 在线不卡欧美精品一区二区三区| 中文字幕在线不卡| 国产日韩欧美不卡| 日韩精品一区二区三区在线观看 | 国产精品一区久久久久| 久久精品免费观看| 婷婷激情综合网| 亚洲老司机在线| 日韩精品一区二区三区视频播放 | 午夜精品成人在线视频| 国产欧美一区二区精品秋霞影院 | 一区二区久久久久| 91小视频在线| 久久香蕉国产线看观看99| 亚洲一区二区视频| 91伊人久久大香线蕉| 中文av字幕一区| 色噜噜狠狠色综合欧洲selulu| 精品日韩欧美一区二区| 五月天中文字幕一区二区| 欧美精品一二三区| 中文子幕无线码一区tr| 免费观看日韩av| 狠狠色狠狠色合久久伊人| 久久国内精品自在自线400部| 日韩av成人高清| 日本美女一区二区三区| 国产麻豆精品在线| 高清不卡一二三区| 欧美日韩一级黄| 色婷婷综合久久久中文字幕| 国产精品久久久久一区| 欧洲另类一二三四区| 日本午夜精品一区二区三区电影| 国产欧美精品一区二区三区四区| 色偷偷成人一区二区三区91| 免费一级片91| 成人免费小视频| 欧美一区二区视频在线观看| 亚洲国产成人一区二区三区| 天天av天天翘天天综合网| 欧美日韩国产免费一区二区 | 波波电影院一区二区三区| 777欧美精品| 亚洲国产中文字幕| 国产麻豆精品视频| 国产精品美女久久久久久2018| 蜜臀av一区二区| 日韩免费性生活视频播放| 亚洲高清在线精品| 色婷婷av一区二区三区软件| 成人免费一区二区三区视频 | 在线中文字幕一区二区| 日韩精品一区二区三区老鸭窝| 亚洲制服丝袜av| 91成人免费在线视频| 亚洲成av人片在线| 欧美一区二区三区免费在线看| 中文字幕第一区综合| 日本道免费精品一区二区三区| 亚洲在线视频免费观看| 精品免费一区二区三区| 欧美老肥妇做.爰bbww| 蜜桃久久久久久久| 国产精品色呦呦| 欧美视频一区二区三区四区 | 亚洲亚洲人成综合网络| 欧美精品久久99久久在免费线| 日本中文字幕一区二区视频 | 99久久er热在这里只有精品15| 国产传媒欧美日韩成人| 日韩电影一区二区三区| 中文字幕的久久| 丰满放荡岳乱妇91ww|