Mysql必知必会(笔记)【SQL游标】
来源:互联网 发布:java虚拟机工作原理 编辑:程序博客网 时间:2024/05/12 20:20
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();
0 0
- Mysql必知必会(笔记)【SQL游标】
- MySQL必知必会笔记(六)存储过程 游标 触发器
- MySQL必知必会笔记(四)存储过程 游标 触发器
- MySQL必知必会笔记(六)存储过程 游标 触发器
- MySQL必知必会笔记(六)存储过程 游标 触发器
- MySQL必知必会笔记(六)存储过程 游标 触发器
- MySQL必知必会笔记(四)存储过程 游标 触发器
- SQL必知必会 笔记 第二十一章 使用游标
- SQL 游标 学习笔记
- 《MySQL必知必会学习笔记》:游标的使用
- SQL学习笔记之游标
- Oralce PL/SQL游标笔记
- T-SQL 游标学习笔记
- pl SQL 学习笔记(五)oracle 游标
- 《MySQL必知必会》学习笔记十四(游标)------了解部分
- MYSQL学习笔记(二十)使用游标
- SQL笔记(MySQL)
- MySQL-SQL之游标,触发器和事务
- VTK User’s Guide -11th edition 第03章-VTK系统概述(2)
- OpenCV Tutorial: 區域生長(floodFill)
- 汇编语言之数据处理的2个基本问题
- Spark与Flink比较
- 菱形继承和虚继承
- Mysql必知必会(笔记)【SQL游标】
- spring-06-如何向响应JSP传值
- OpenCV Tutorial: 分水嶺算法(watershed)
- Xcode 8如何继续使用插件
- php中使用python生成excel报表
- Android——RecyclerView——使用ItemDragHelper来实现酷炫拖拽效果
- Android Material Design之Toolbar与Palette实践
- 彻底卸载ORACLE数据库
- shiro初步学习