MySQL游标的简单实践
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游标的简单实践的更多相关文章
- 利用navicat创建存储过程、触发器和使用游标的简单实例
利用navicat创建存储过程.触发器和使用游标的简单实例 标签: navicat存储过程触发器mysql游标 2013-08-03 21:34 15516人阅读 评论(1) 收藏 举报 分类: 数 ...
- SqlServer和MySQL游标学习
一 sqlserver游标使用 /*** 游标的使用 讲了这个多游标的优点,现在我们就亲自来揭开游标的神秘的面纱. 使用游标的顺序: 声名游标.打开游标.读取数据.关闭游标.删除游标. 1.3.1 ...
- mysql 游标 demo
一.MySQL游标的概念 1.游标介绍 MySQL的游标(cursor)是一个重要的概念,通过查找资料与自己的理解,主要得出以下几点关于自己的理解. 有数据缓冲的思想:游标的设计是一种数据缓冲区的思想 ...
- Mycat(4):消息表mysql数据库分表实践
本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/46882777 未经博主同意不得转载. 1,业务需求 比方一个社交软件,比方像腾讯 ...
- Linux实战教学笔记29:MySQL数据库企业级应用实践
第二十九节 MySQL数据库企业级应用实践 一,概述 1.1 MySQL介绍 MySQL属于传统关系型数据库产品,它开放式的架构使得用户选择性很强,同时社区开发与维护人数众多.其功能稳定,性能卓越,且 ...
- 进击的Python【第十二章】:mysql介绍与简单操作,sqlachemy介绍与简单应用
进击的Python[第十二章]:mysql介绍与简单操作,sqlachemy介绍与简单应用 一.数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数 ...
- mysql主从复制原理及实践
Mysql主从复制原理及实践 mysql主从框架 MySQL主从架构是MySQL集群中最基本也是最常用的一种架构部署,能够满足很多业务需求,常见的有一主一从或者一主多从.可以防止单一主机的 ...
- Mysql 游标初识
MySql 游标初识 认识 游标(cursor), 按字面意思可理解为, 游动的标识, 或者叫做"光标", 这样更容易理解. 就好比现有一张表存储了n行记录, 然后我想每次取出一行 ...
- MySQL数据库企业级应用实践(主从复制)
MySQL数据库企业级应用实践(主从复制) 链接:https://pan.baidu.com/s/1ANGg3Kd_28BzQrA5ya17fQ 提取码:ekpy 复制这段内容后打开百度网盘手机App ...
随机推荐
- dreamweaver中的 map怎么调用?_制作热点图像区域
我们浏览网页时,经常看到一些图片上会出现特别的超链接,即在一张图片上有多个局部区域和不同的网页链接,比如地图链接. 这就是映射图像(Image Map),它是指一幅根据链接对象不同而被人为划分为若干指 ...
- Python中的元祖Tuple
Python中的元祖和list基本上一样 tuple = () # 表示一个空的元祖 tuple = (50, ) # 元组中只有一个元素的时候,必须在后面加上逗号 无关闭分隔符 任意无符号的对象,以 ...
- Ubuntu 16.04系统下出现E: 无法下载 http://ppa.launchpad.net/fcitx-team/nightly/ubuntu/dists/xenial/main/binary-amd64/Packages 404 Not Found
在安装完成Chrome浏览器后,终端执行以下更新命令 sudo apt-get update 时出现E: 无法下载 http://ppa.launchpad.net/fcitx-team/nightl ...
- bing翻译API调用方法
概述 前一段时间,遇到一个需求,需要对文章进行翻译,由于客户公司员工有国内的人员,也有国外的人员,为了照顾国外的同事,客户提出,当用户在手机端发布帖子,需要同时把帖子的内容翻译成英文,方便用户阅读.于 ...
- quartz笔记
首先网络上的很多教程经常有错(信息过载了),其主要原因是版本发生了变化,例如quartz1和2之间还是有不少差别的,导致查找资料的人浪费了不少时间.所以无论教程如何写,都建议读者首先学习官网的教程,如 ...
- SharePoint JavaScript 客户端对象使用视频教程
本次视频教程是为大家介绍如何使用SharePoint JavaScript客户端对象,包括对于站点.列表.文档库.列表项.文件夹.文件和附件等基本对象的操作,同时,为大家举几个简单的应用的例子,让大家 ...
- Mac端SVN工具CornerStone详解
俗话说:"工欲善其事必先利其器": 对于我们程序员来说,不管你是大神,还是小鱼小虾,进入公司之后,都用过源码管理工具,不然你就不是一个合格的程序员,现在各个公司用于源码管理工具通常 ...
- 3.Redis常用命令:String
字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等.在Redis中字符串类型的Value ...
- idea + mybatis generator + maven 插件使用
idea + mybatis generator + maven 插件使用 采用的是 generator 的 maven 插件的方式 ~ 1 pom.xml mybatis其它配置一样,下面是配置my ...
- Linux 入门笔记
一开始对linux总有些抵触,黑黑的命令框不知道如何下手,这次因为工作交接的缘故需要负责之前同事的Node后端部分,node,redis这些都是部署在Linux上的,看了几次运维的同学噼里啪啦的敲命令 ...