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 ...
随机推荐
- gcc下c++的对象模型 (1)
所有示例代码在如下环境中执行 ubuntu 16.04.4 (64位) gcc version 5.4.0 开启std11 gdb version 7.11.1 1. 空类的大小 定义一个空类A,实例 ...
- Dive in python Chapter3 实例
def buildConnectionString(params): """Build a connection string from a dictionary Ret ...
- Java Swing客户端小项目
记录一下两个用java swing写的客户端. 项目1: 关键词:swing jtable 代码如下: 1.主类: package com.my.agent.client; import java. ...
- 使用idea2017搭建SSM框架
搭建个SSM框架居然花费了我好长时间!特此记录! 需要准备的环境: idea 2017.1 jdk1.8 Maven 3.3.9 请提前将idea与Maven.jdk配置好,本次项目用的都是比较新的 ...
- vue2.0transition过渡的使用介绍
直接上代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...
- Linux ubuntu 安装gcc、g++、 pcre、zlib、ssl、nginx和该内存不能为written解决方法
1.楼主也是第一次接触Linux 如果有错误的地方还请各位朋友指出.... 2.gcc.g++依赖库:sudo apt-get install build-essential,sudoapt-get ...
- Where T:Class,new()的使用
当我们使用泛型的时候,有时候就会提示我们T必须是引用类型而无法进行下去,其实我们学泛型的时候也应该了解到这个T的使用场合,他可以是值类型也可以是引用类型,但是我们某些场合就只能使用引用类型比如EF中的 ...
- 01.PHP5.x编译详解
##PHP5.5编译安装 ``` wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo yum i ...
- 踩坑实录 Android studio中关于 No cached version of **** available for of处理办法
当我们添加某些依赖库(Okhttp.Retrofit)时, Android studio 会报如下错误: Error:A problem occurred configuring project ': ...
- servlet学习总结(一)——初识Servlet
Servlet工作过程 当客户端向web服务器发送servlet请求时,web服务器首先检查是否已经加载并创建了servlet实例对象.如果没有会装载并创建该Servlet的一个实例对象.然后调用se ...