mysql游标的原理与用法实例分析

 更新时间:2020年04月10日 10:37:48   作者:随风行云  
这篇文章主要介绍了mysql游标的原理与用法,结合实例形式分析了mysql游标的概念、原理、用法及操作注意事项,需要的朋友可以参考下

本文实例讲述了mysql游标的原理与用法。分享给大家供大家参考,具体如下:

本文内容:

  • 什么是游标
  • 创建游标
  • 使用游标

首发日期:2018-04-18


什么是游标:

  • 如果你前面看过mysql函数,会发现无法使用返回多行结果的语句。但如果你又确实想要使用时,就需要使用到游标,游标可以帮你选择出某个结果(这样就可以做到返回单个结果)。
  • 另外,使用游标也可以轻易的取出在检索出来的行中前进或后退一行或多行的结果。
  • 游标可以遍历返回的多行结果。

补充:

  • Mysql中游标只适用于存储过程以及函数。


创建游标:

  • 语法:
    • 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 -- 循环,将表的内容都转移到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 -- 循环,将表的内容都转移到class2中
      fetch mc into id,name;
      -- 这里是为了显示获取结果
      insert into class2 values(id,name);
      -- 关闭游标
      end loop;
      close mc;
      
    end;

上面的代码会有一个报错image,不断循环的话,始终会达到表的末尾,到了末尾就无法继续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会触发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查询结果实现多列拼接查询

    mysql查询结果实现多列拼接查询

    本文主要介绍了mysql查询结果实现多列拼接查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • SQL函数Group_concat的用法及说明

    SQL函数Group_concat的用法及说明

    这篇文章主要介绍了SQL函数Group_concat的用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • win32 mysql 5.7.27 安装配置方法图文教程

    win32 mysql 5.7.27 安装配置方法图文教程

    这篇文章主要为大家详细介绍了win32 mysql 5.7.27 安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • MYSQL(电话号码,身份证)数据脱敏的实现

    MYSQL(电话号码,身份证)数据脱敏的实现

    在日常开发需求中会经常遇到数据脱敏处理,比如身份证号、手机号,需要使用*进行部分替换显示。这样能使敏感隐私信息在一定程度上得到保护。本文就来介绍一下
    2021-05-05
  • MySQL数据库备份方法说明

    MySQL数据库备份方法说明

    MySQL数据库备份方法说明...
    2007-07-07
  • 如何更改MySQL数据库的编码为utf8mb4

    如何更改MySQL数据库的编码为utf8mb4

    utf8mb4编码是utf8编码的超集,兼容utf8,并且能存储4字节的表情字符。 这篇文章给大家介绍了更改MySQL数据库的编码为utf8mb4的相关知识,感兴趣的朋友一起看看吧
    2020-02-02
  • 阿里云配置MySQL-server 8.0远程登录的实现

    阿里云配置MySQL-server 8.0远程登录的实现

    我们经常会碰到需要远程访问数据库的场景,本文主要介绍了阿里云配置MySQL-server 8.0远程登录的实现,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • mysql通过文档读取并执行命令之快速为mysql添加多用户和数据库技巧

    mysql通过文档读取并执行命令之快速为mysql添加多用户和数据库技巧

    这篇文章主要介绍了mysql通过文档读取并执行命令之快速为mysql添加多用户和数据库技巧的相关资料,需要的朋友可以参考下
    2015-09-09
  • mysql8.0.27配置步骤以及注意事项

    mysql8.0.27配置步骤以及注意事项

    这篇文章主要给大家介绍了关于mysql8.0.27配置步骤以及注意事项的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03
  • mysql存储emoji表情步骤详解

    mysql存储emoji表情步骤详解

    在本篇内容中小编给大家整理了关于mysql存储emoji表情的详细步骤以及知识点,需要的朋友们学习下。
    2019-03-03

最新评论