亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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;

上面的代碼會有一個報錯image,不斷循環(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數據庫計有所幫助。

相關文章

  • MySQL group_concat函數使用方法詳解

    MySQL group_concat函數使用方法詳解

    GROUP_CONCAT函數用于將GROUP BY產生的同一個分組中的值連接起來,返回一個字符串結果,接下來就給大家簡單的介紹一下MySQL group_concat函數的使用方法,需要的朋友可以參考下
    2023-07-07
  • 在IDEA的maven項目中連接并使用MySQL8.0的方法教程

    在IDEA的maven項目中連接并使用MySQL8.0的方法教程

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

    MySQL8.0 MGR的維護管理

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

    MySQL數據庫之內置函數和自定義函數 function

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

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

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

    MySQL中獲取當前時間格式的方法匯總

    在MySQL數據庫開發(fā)中,獲取時間是一個常見的需求,MySQL提供了多種方法來獲取當前日期、時間和時間戳,并且可以對時間進行格式化、計算和轉換,以下是一些常用的MySQL時間函數及其示例,需要的朋友可以參考下
    2024-06-06
  • 查看 MySQL 已經運行多長時間的方法

    查看 MySQL 已經運行多長時間的方法

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

    textarea標簽(存取數據庫mysql)的換行方法

    textarea標簽本身不識別換行功能,回車換行用的是\n換行符,輸入時的確有換行的效果,但是html渲染或者保存數據庫mysql時就只是一個空格了,這時就需要利用換行符\n和br標簽的轉換進行處理
    2023-09-09
  • MSQL中DATETIME或TIMESTAMP的區(qū)別小結

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

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

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

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

最新評論