SQL:第六章显式游标_第1页
SQL:第六章显式游标_第2页
SQL:第六章显式游标_第3页
SQL:第六章显式游标_第4页
SQL:第六章显式游标_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论