Mysql必知必会(笔记)【SQL游标】

本文介绍了MySQL中游标的概念、特性和使用方法,并提供了一个具体的游标使用案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysql被oracle收购后,从mysql-5.5开始,将InnoDB作为默认存储引擎,是一次比较重大的突破。InnoDB作为支持事务的存储引擎,拥有相关的
RDBMS特性:包括ACID事务支持,数据完整性(外健),灾难恢复能力等特性。

一 什么是游标(cursor)


一个cursor,就是一个标识,用来标识数据取到什么地方了。你也可以把它理解成数组中的下标。

二 游标(cursor)的特性


1,只读的,不能更新的。
2,不滚动的
3,不敏感的,不敏感意为服务器可以活不可以复制它的结果表
游标(cursor)必须在声明处理程序之前被声明,并且变量和条件必须在声明游标或处理程序之前被声明。

三 使用游标(cursor)


1.声明游标

DECLARE 游标名 CURSOR FOR select语句;

这个语句声明一个游标。也可以在子程序中定义多个游标,但是一个块中的每一个游标必须有唯一的。

2. 游标OPEN语句

OPEN 游标名;

这个语句打开先前声明的游标。

3. 游标FETCH语句

FETCH 游标名 INTO 变量,变量 …
这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针。
Mysql是通过一个Error handler的声明来进行判断的指针是否到尾,

declare continue handler for Not found (do some action);

在Mysql里当游标遍历溢出时,会出现一个预定义的NOT FOUND的Error,我们处理这个Error并定义一个continue的handler就可以了。
定义一个flag,在NOT FOUND,标示Flag,在Loop里以这个flag为结束循环的判断就可以了。

4. 游标CLOSE语句

CLOSE 游标名;

这个语句关闭先前打开的游标。

四 游标案例(cursor)

delimiter //
//创建一个存储过程,在存储过程中声明游标
drop procedure if exists test.bankProc;
create procedure test.bankProc() 
begin 
declare tmpName varchar(30) default '';
declare allName varchar(120) default ''; 
declare cur1 cursor for select name from test.bank;
declare continue handler for sqlstate'02000' set tmpName=null; open cur1;
(declare continue handler for not found set tmpName=null)
fetch cur1 into tmpName;
while(tmpName is  not null)
Do 
set tmpName=concat(tmpName,";");
set allName=concat(allName,tmpName);
fetch cur1 into tmpName;
end while;close cur1;
select allName;
select TmpName;
end//
delimiter ;
//对存储过程进行调用
call test.bankProc();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NobiGo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值