欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql游標(biāo)的原理與用法實(shí)例分析

 更新時(shí)間:2020年04月10日 10:37:48   作者:隨風(fēng)行云  
這篇文章主要介紹了mysql游標(biāo)的原理與用法,結(jié)合實(shí)例形式分析了mysql游標(biāo)的概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下

本文實(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ò)image,不斷循環(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ì)有所幫助。

相關(guān)文章

  • MySQL group_concat函數(shù)使用方法詳解

    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的方法教程

    這篇文章主要介紹了如何在IDEA的maven項(xiàng)目中連接并使用MySQL8.0,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • MySQL8.0 MGR的維護(hù)管理

    MySQL8.0 MGR的維護(hù)管理

    數(shù)據(jù)庫已成為企業(yè)和管理員們最為關(guān)注的核心組件之一,本文主要介紹了MySQL8.0 MGR的維護(hù)管理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function

    MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function

    這篇文章主要介紹了MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-06-06
  • 一文弄懂MySQL索引創(chuàng)建原則

    一文弄懂MySQL索引創(chuàng)建原則

    在關(guān)鍵字段的索引上建與不建索引,查詢速度相差近100倍,但差的索引和沒有索引效果一樣,索引并非越多越好,因?yàn)榫S護(hù)索引需要成本,下面這篇文章主要給大家介紹了關(guān)于MySQL索引創(chuàng)建原則的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • MySQL中獲取當(dāng)前時(shí)間格式的方法匯總

    MySQL中獲取當(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 已經(jīng)運(yùn)行多長時(shí)間的方法

    查看MySQL啟動(dòng)時(shí)間以及運(yùn)行了多長時(shí)間的方法有利用show與updtime或在linux中直接使用grep mysql 相關(guān)參數(shù)來查看,下面我們一起來看看
    2014-01-01
  • textarea標(biāo)簽(存取數(shù)據(jù)庫mysql)的換行方法

    textarea標(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-09
  • MSQL中DATETIME或TIMESTAMP的區(qū)別小結(jié)

    MSQL中DATETIME或TIMESTAMP的區(qū)別小結(jié)

    MySQL中的?DATETIME?和?TIMESTAMP?類型都用于存儲(chǔ)日期和時(shí)間信息,本文主要介紹了MSQL中DATETIME或TIMESTAMP的區(qū)別小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • mysql使用教程之分區(qū)表的使用方法(刪除分區(qū)表)

    mysql使用教程之分區(qū)表的使用方法(刪除分區(qū)表)

    mysql分區(qū)表使用方法,新增分區(qū)、刪除分區(qū)、分區(qū)的合并、分區(qū)的拆分等使用方法
    2013-12-12

最新評論