Oracle游标(CURSOR)

php中文网
发布: 2016-06-07 17:13:12
原创
1279人浏览过

PL/SQL包含两种游标:1.显示游标 2.隐式游标 显示游标:语法: CUROSR cursor_name is select_statement;打开游标:open cursor_

PL/SQL包含两种游标:1.显示游标 2.隐式游标

显示游标:
语法:
CUROSR cursor_name is select_statement;
打开游标:open cursor_name;
提取数据:两种:1.FETCH curosr_name INTO varible1,variable2....;
       2.FETCH cursor_name BULK COLLECT INTO  collect1,collect2,....[LIMIT rows];
关闭游标:CLOSE cursor_name;

显示游标属性:
1.%ISOPEN:该属性用于确定游标是否已经打开。如果打开,返回true, 否则返回false;
2.%FOUND:该属性检查是否从数据集中提取到了数据。有数据为true,反之为false;
3.%NOTFOUND:与%FOUND相反。
4.%ROWCOUNT:返回当前行为已经提取到的实际行数。

注意:1.当用FETCH已经取到游标的末尾时,再对游标进行取值,游标会返回结果集中的最后一条记录,因为,当游标再结果集中取不到值时会返回给用户游标缓冲区的内容(也就是结果集中的最后一条记录);
2.以上的属性只针对于游标的当前状态。
3.之前的嵌套表、变长数组的使用都是需要初始化的,这里注意的是:当在显示游标中使用FETCH语句对嵌套表或变长数组赋值时,是不需要初始化大小的。

参数游标:
语法:CURSOR cursor_name(parameter_name datatype)IS select_statement;
1.对于游标的参数可以使用DEFAULT关键字对参数设置默认值,调用时若不给此参数传值,则会调用默认值。
2.对参数游标进行取值时只能用FETCH(一般的游标,可以使用for遍历取值);

使用游标更新或删除数据:
语法:(更新)UPDATE table_name SET column=.. WHERE CURRENT OF cursor_name;
     (删除)DELETE FROM table_name WHERE CURRENT OF cursor_name;
1.在对 游标进行更行时需要在游标语法后面加上 for update [,WAIT num][,OF col];
解析:for update:表名此游标对所使用的表独占,防止其他人对此表同时操作。
      wait:wait 秒数,,指当所操作的表被锁定时,等待几秒再执行,若依然是锁定状态,则会抛出异常,可以设置为NOWAIT不需要等待。
      OF col:列级锁,使用此锁的列所在的一行记录都被锁定。

游标变量:
语法:TYPE ref_type_name IS CURSOR [RETURN return_type];
创建完类型后要使用需要声明:cursor_name ref_type_name;
打开游标:OPEN cursor_name for select_statement;
使用FETCH取值:与显示游标一样。
关闭游标:与显示游标一样。

语法解析:
[RETURN return_type]:类型限制,只能返回限定的数据类型;

更多Oracle相关信息见Oracle 专题页面 ?tid=12

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号