




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、显式游标,本章目的,完成本章之后,我们应掌握以下的内容: 区别显式游标与隐式游标 使用PL/SQL record变量 编写一个 Cursor FOR loop,关于游标,每一个被执行SQL语句都有一个私有的游标 隐式游标: 所有的DML及SELECT都会有一个隐式游标 显式游标: 由编程人员定义,显式游标的功能,结果集(Result Set,当前行,7369SMITHCLERK 7566JONESMANAGER 7788SCOTTANALYST 7876ADAMSCLERK 7902FORDANALYST,使用显式游标来分别处理由select返回的多个行,控制显式游标,定义一个游标的名字及所用
2、到的查询语句,DECLARE,打开游标,执行查询,查询到的集合叫做活动集合(active set,把活动集的当前行load到变量,测试游标所在位置是否存在行,如果存在行则转到 FETCH,No,释放活动集( active set,控制显式游标,打开游标,从指针所在位置取出一行,继续处理,直到为空,关闭游标,定义游标,语法,CURSOR cursor_name IS select_statement,定义游标,例子,DECLARE CURSOR c1 IS SELECT empno, ename FROM emp; CURSOR c2 IS SELECT * FROM dept WHERE de
3、ptno = 10; BEGIN,打开游标,语法 打开游标,执行查询并确定活动集(active set) 如果查询结果没有返回行,不会有出错处理,OPENcursor_name,从游标提取数据(fetch data,语法 把当前行的值送到变量里面 包括同样数量的变量 每个变量要与查询对应的列一致,FETCH cursor_name INTOvariable1, variable2, . | record_name,从游标提取数据(fetch data,例子,FETCH c1 INTO v_empno, v_ename,OPEN defined_cursor; LOOP FETCH define
4、d_cursor INTO defined_variables EXIT WHEN .; . - Process the retrieved data . END,关闭游标,语法 完成对行的处理后关闭游标,释放内存 游标关闭之后,就无法从游标提取数据,CLOSEcursor_name,显式游标的属性,取得关于游标的状态信息,AttributeType Description %ISOPENBoolean Evaluates to TRUE if the cursor is open %NOTFOUNDBoolean Evaluates to TRUE if the most recent fe
5、tch does not return a row %FOUNDBoolean Evaluates to TRUE if the mostrecent fetch returns a row; complement of %NOTFOUND %ROWCOUNTNumberEvaluates to the total number of rows returned so far,控制多个提取(Multiple Fetches,使用循环对一个返回多行的显式游标进行处理 一个循环提取一行 使用%NOTFOUND 属性来判断一个不成功的提取(fetch,ISOPEN 属性,只有当游标是打开的时候,才可
6、以提取行 使用%ISOPEN 这个游标的属性来判断游标是否打开 例子,IF NOT c1%ISOPEN THEN OPEN c1; END IF; LOOP FETCH c1,NOTFOUND 和%ROWCOUNT 属性,使用游标的%ROWCOUNT 属性来取得满足条件的行的数量 使用游标的%NOTFOUND 属性来判断是否离开循环,游标(Cursors)和记录(Records,通过把值送给PL/SQL RECORD,来方便对活动集合里面行的处理 例子,CURSOR c1 IS SELECTempno, ename FROMemp; emp_recordc1%ROWTYPE; BEGIN OP
7、EN c1; . . . FETCH c1 INTO emp_record,语法 处理显式游标的一个捷径 隐含open, fetch, 和close 不需要定义记录(record) ,它被隐含定义,Cursor FOR Loops,FOR record_name IN cursor_name LOOP statement1; statement2; . . . END LOOP,Cursor FOR Loops,把所有员工资料一行一行取出来 例子,DECLARE CURSOR c1 IS SELECT empno, ename FROM emp; BEGIN FOR emp_record IN
8、 c1 LOOP - implicit open and implicit fetch occur IF emp_record.empno = 7839 THEN . END LOOP; - implicit close occurs END,使用子查询的Cursor FOR Loops,无需定义游标. 例子,BEGIN FOR emp_record IN ( SELECT empno, ename FROM emp) LOOP - implicit open and implicit fetch occur IF emp_record.empno = 7839 THEN . END LOOP; - i
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 班组长安全考试题及答案
- 儿童汉字教学课件
- 2025年金融科技赋能财富管理新趋势下的客户满意度分析报告
- 2025年金融反欺诈技术革新与大数据在欺诈识别中的实战策略报告
- 葡萄课件教学目标
- 安徽省全国示范高中名校2025届化学高二下期末学业质量监测试题含解析
- 花园种花教学课件
- 纠结面授课有没有用?执业医师笔试考生需知的面授核心优势
- 亲子游泳教学课件
- 竹编教学课件图片模板
- DB37-T5311-2025建筑工程消防设计文件编制标准
- 成都市高新区2023年七年级《历史》下册期末试卷与参考答案
- 中国上市银行2024年回顾及未来展望-安永-202505
- TSG Z7002-2022特种设备检测机构核准规则
- 装修售后维修合同协议
- 2025年数字经济下的创业政策调整策略试题及答案
- 第30课 在线安全防范-2024-2025学年三年级全一册《信息技术》教案
- 政治 (道德与法治)八年级下册自由平等的追求教案
- 山东省济南市高新区学卷B2024-2025学年数学五下期末教学质量检测试题含答案
- 订单外发合同协议
- 山东省2024年艺术类本科批音乐类第1次志愿投档情况表(公布)
评论
0/150
提交评论