Q:为什么要使用游标?

A:

  在存储过程(或函数)中,如果某条select语句返回的结果集中只有1行,可以使用select into语句(上几篇博客有介绍到用法)来得到该行进行处理;如果结果集中有多行,简单的select语句成批地进行处理,需要在检索出来的行中前进或后退一行或多行……若是想得到其中的每一行进行处理,就必须使用游标。

Q:什么是游标?

A:

  游标(cursor),是一个存储在MySQL服务器上的数据库查询,游标不是一条 SELECT语句,而是被该语句检索出来的结果集;可以看做是指向查询结果集的指针;通过cursor,就可以一次一行的从结果集中把行拿出来处理。

注意:MySQL游标只能用于存储过程和函数。

游标的处理过程:4步

  ①声明游标declare:没有检索数据,只是定义要使用的select语句

  ②打开游标open:打开游标以供使用,用上一步定义的select语句把数据实际检索出来

  ③检索游标fetch:对于填有数据的游标,根据需要取出(检索)各行

  ④关闭游标close:在结束游标使用时,必须关闭游标

1、声明游标

DECLARE cursor_name CURSOR FOR select_statement;

声明一个游标cursor_name,让其指向查询select_statement的结果集。

注意:

  ①游标声明必须出现在变量和条件声明的后面,但是在异常处理声明的前面

  ②一个过程中可以有多个游标声明

2、打开游标

OPEN cursor_name;

cursor_name是声明中定义的名字;打开游标时才执行相应的select_statement。

3、检索游标

FETCH  cursor_name INTO var_name [, var_name] ...

从游标cursor_name中拿出一行,把该行的各个列值保存到各个变量中。

解析:

  一次只拿一行,拿完后,自动移动指针到下一行;

  如果没有拿到行,会抛出异常,其SQLSTATE代码值为‘02000’,此时要检测到该情况,需要声明异常处理程序 (针对条件NOT FOUND也可以),通常需要在一个循环中来执行fetch语句,通过检测以上异常来结束循环。

4、关闭游标

CLOSE cursor_name;

收回游标占用的内存,别浪费资源嘛。

例1:创建过程,计算players表中行的数量

mysql> delimiter $$
mysql> create procedure number_of_players(
->   out pnumber int)
-> begin
->   declare a_playerno int;
->   declare found bool default true;  循环控制变量,其值为false时循环结束
->
->   declare c_players cursor for
->     select playerno from PLAYERS; ①声明游标
->
->   declare continue handler for not found
->     set found=false; 声明异常处理程序
->
->   set pnumber=;
->
->   open c_players; ②打开游标
->
->   fetch c_players into a_playerno; ③检索游标(检索第一行)
->   while found do
->     set pnumber=pnumber+;
->     fetch c_players into a_playerno;
->   end while; 循环检索其余行
->
->   close c_players; ④关闭游标
-> end$$
mysql> delimiter ;
mysql> call number_of_players(@pnumber);
mysql> select @pnumber;
+----------+
| @pnumber |
+----------+
| |
+----------+
mysql> select count(*) from PLAYERS;
+----------+
| count(*) |
+----------+
| |
+----------+

例2:创建过程,计算某个球员的罚款次数--游标声明中可以包含变量

mysql> delimiter $$
mysql> create procedure number_penalties(
->   in p_playerno int,
->   out pnumber int)
-> begin
->   declare a_playerno int;
->   declare found bool default true; 循环控制变量
->
->   declare c_players cursor for 声明游标
->     select playerno
->     from PENALTIES
->     where playerno = p_playerno; 包含变量p_playerno
->
->   declare continue handler for not found
->     set found=false; 声明异常处理程序
->
->   set pnumber=;
->
->   open c_players; 打开游标
->
->   fetch c_players into a_playerno;
->   while found do 循环检索游标每一行
->     set pnumber=pnumber+;
->     fetch c_players into a_playerno;
->   end while;
->
->   close c_players; 关闭游标
-> end$$
mysql> delimiter ;
mysql> call number_penalties(,@pnumber);
mysql> select @pnumber;
+----------+
| @pnumber |
+----------+
| |
+----------+

MySQL游标的简单实践的更多相关文章

  1. 利用navicat创建存储过程、触发器和使用游标的简单实例

    利用navicat创建存储过程.触发器和使用游标的简单实例 标签: navicat存储过程触发器mysql游标 2013-08-03 21:34 15516人阅读 评论(1) 收藏 举报  分类: 数 ...

  2. SqlServer和MySQL游标学习

    一 sqlserver游标使用 /*** 游标的使用  讲了这个多游标的优点,现在我们就亲自来揭开游标的神秘的面纱.  使用游标的顺序: 声名游标.打开游标.读取数据.关闭游标.删除游标. 1.3.1 ...

  3. mysql 游标 demo

    一.MySQL游标的概念 1.游标介绍 MySQL的游标(cursor)是一个重要的概念,通过查找资料与自己的理解,主要得出以下几点关于自己的理解. 有数据缓冲的思想:游标的设计是一种数据缓冲区的思想 ...

  4. Mycat(4):消息表mysql数据库分表实践

    本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/46882777 未经博主同意不得转载. 1,业务需求 比方一个社交软件,比方像腾讯 ...

  5. Linux实战教学笔记29:MySQL数据库企业级应用实践

    第二十九节 MySQL数据库企业级应用实践 一,概述 1.1 MySQL介绍 MySQL属于传统关系型数据库产品,它开放式的架构使得用户选择性很强,同时社区开发与维护人数众多.其功能稳定,性能卓越,且 ...

  6. 进击的Python【第十二章】:mysql介绍与简单操作,sqlachemy介绍与简单应用

    进击的Python[第十二章]:mysql介绍与简单操作,sqlachemy介绍与简单应用 一.数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数 ...

  7. mysql主从复制原理及实践

    Mysql主从复制原理及实践 mysql主从框架       MySQL主从架构是MySQL集群中最基本也是最常用的一种架构部署,能够满足很多业务需求,常见的有一主一从或者一主多从.可以防止单一主机的 ...

  8. Mysql 游标初识

    MySql 游标初识 认识 游标(cursor), 按字面意思可理解为, 游动的标识, 或者叫做"光标", 这样更容易理解. 就好比现有一张表存储了n行记录, 然后我想每次取出一行 ...

  9. MySQL数据库企业级应用实践(主从复制)

    MySQL数据库企业级应用实践(主从复制) 链接:https://pan.baidu.com/s/1ANGg3Kd_28BzQrA5ya17fQ 提取码:ekpy 复制这段内容后打开百度网盘手机App ...

随机推荐

  1. (14)jdk1.5开始的一些新特性:静态导入,增强for循环,可变参数,自动装箱/拆箱,枚举类型

    Jdk1.5新特性之静态导入 jdk1.5新特性值静态导入 静态导入的作用:简化缩写 静态导入的作用:可以作用一个类的所有静态成员. 静态导入的格式:import static 包名.类名.静态的成员 ...

  2. 使用Hibernate中出现了Caused by: java.sql.SQLException: Field 'gid' doesn't have a default value

    那是因为表中没有设置主键自动增长,只需要改变表中的主键设置为自动增长即可

  3. SocketServer模块

    在利用select实现伪并发的socket博文中我们说了: 如果要实现一个server端可以和多个客户端进行通信可以使用 1.多线程 2.多进程 3.select I/O多路复用 在那篇博文中我们介绍 ...

  4. MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ...

    下面是我update数据库时打印出来的异常: ### Error updating database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSynt ...

  5. Android开发艺术2之Activity的启动模式

    Activity是Android的四大组件之一,他的重要性毋庸置疑,对于这么重要的一个组件,我们首先要知道这些都是由系统进行管理和回调的,要理解Activity的启动模式,我们首先来了解一下Andro ...

  6. 7.Redis常用命令:ZSet

    Sorted-Sets和Sets类型极为相似,它们都是字符串的集合,都不允许重复的成员出现在一个Set中.它们之间的主要差别是Sorted-Sets中的每一个成员都会有一个分数(score)与之关联, ...

  7. SQL语句中的日期查询

    我们先创建一个表: CREATE TABLE `student` ( `id` INT NOT NULL AUTO_INCREMENT , `name` VARCHAR(10) NULL COMMEN ...

  8. Android kernel LOGO的更换方法

    [从制作logo到LCD显示或者VGA显示logo] 1.制作logo的方法: 首先选择一个自己喜欢的图片,然后通过GIMP软件将该图片保存为.png格式, 变换方式这个就不说了(very easy) ...

  9. UPS不间断电源网络功能介绍

    UPS不间断电源网络功能介绍 随着联网技术的善及,用户又向UPS提出了更高的要求:ups电源应具有无人値守的功铅酸蓄电池能,不但具有自检的功能,还应具有联网功能,在网上UPS不间断电源可以随时观察up ...

  10. Linux嵌入式开发中常用的两个工具

    TFTP 全称:Trivial File Transfer Protocol(简单文件传输协议) 进行小文件传输 在ubuntu下设置TFTP服务器 $ sudo apt-get install tf ...