mysql游标示例mysql游标简易教程
来源:互联网 发布:expect for windows 编辑:程序博客网 时间:2024/06/13 01:13
从mysql V5.5开始,进行了一次大的改变,就是将InnoDB作为默认的存储引擎。InnoDB支持事务,而且拥有相关的RDBMS特性:ACID事务支持,数据完整性(支持外键),灾难恢复能力等等。
现在简单总结一下游标的知识。
(一),认识游标(cursor)
就是一个可读的标识,用来标识数据取到什么地方了。
(二),游标特性
1,只读
2,不滚动
3,不敏感的
(三),使用游标
需要强调的是,游标必须在定义处理程序之前被定义,但变量必须在定义游标之前被定义,顺序就是变量定义-游标定义-处理程序。
1.定义游标
DECLARE cursor_name CURSOR FOR select_statement
这个语句声明一个游标。也可以在子程序中定义多个游标,一个块中的每一个游标必须命名唯一。声明游标后也是单条操作的。
2. 游标OPEN
OPEN cursor_name
这个语句打开先前声明的游标。
3. 游标FETCH
FETCH cursor_name INTO var_name [, var_name] ...
这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针至该行。
4. 游标CLOSE
CLOSE cursor_name
这个语句关闭先前打开的游标,注意,用完后必须关闭。
(四)示例,下面是一个存储过程,里面用到游标,逐条更新数据(批量更新数据)
BEGIN DECLARE no_more_record INT DEFAULT 0; DECLARE pID BIGINT(20); DECLARE pValue DECIMAL(15,5); DECLARE cur_record CURSOR FOR SELECT colA, colB from tableABC; /*首先这里对游标进行定义*/ DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_record = 1; /*这个是个条件处理,针对NOT FOUND的条件,当没有记录时赋值为1*/ OPEN cur_record; /*接着使用OPEN打开游标*/ FETCH cur_record INTO pID, pValue; /*把第一行数据写入变量中,游标也随之指向了记录的第一行*/ WHILE no_more_record != 1 DO INSERT INTO testTable(ID, Value) VALUES (pID, pValue); FETCH cur_record INTO pID, pValue; END WHILE; CLOSE cur_record; /*用完后记得用CLOSE把资源释放掉*/END
0 0
- mysql游标示例mysql游标简易教程
- mysql游标示例mysql游标简易教程
- mysql游标示例 mysql游标简易教程 mysql批量操作数据 mysql批量更新数据 mysql逐条更新数据
- mysql进阶(三)游标简易教程
- MySQL游标循环示例
- MYSQL 游标使用示例
- 记录mysql 游标使用示例
- MySQL存储过程游标示例
- MYSQL游标嵌套循环示例
- mysql 存储过程 游标 示例
- MySQL事物和游标示例
- Mysql 游标
- mysql 游标
- MySQL游标
- mysql 游标
- MySQL游标
- mysql游标
- mySQL游标
- React组件样式
- PHP输出多个变量
- 提升CSS的性能和效率
- 自动水印使用指南
- Tomcat工作原理(二)一个简单的Servlet容器
- mysql游标示例mysql游标简易教程
- Java中的值传递和引用传递
- 如何学习JAVA编程
- 模板常量
- 关于zTree插件的使用
- bzoj 2597: [Wc2007]剪刀石头布(费用流)
- 面试题27:二叉搜索树与双向链表
- qemu中的Hbitmap数据结构
- 大家乐捕鱼游戏里的onOpen函数