游标(Cursor):用来查询数据库,获取记录集合(结果集)的指针,可以让开发者一次访问一行结果集,在每条结果集上作操作。

游标可分为:

1.       静态游标:分为显式(explicit)游标和隐式(implicit)游标。

2.       REF游标:是一种引用类型,类似于指针。

1、静态游标

1.1显式游标

定义格式:

CURSOR 游标名 ( 参数 )  IS

Select 语句FOR UPDATE [OF [schema.]table.column[,[schema.]table.column]..

[nowait]

例子1 :无参数,打开关闭游标

set serveroutput on size 10000000 ;

create or replace procedure TEST is

cursor c1 is

select tname from tab;

pname varchar2(32);

begin

open c1;

loop

fetch c1

into pname;

exit when c1%notfound;

dbms_output.put_line(pname);

end loop;

close c1;

end TEST

exec test;

例子2 :参数使用,参数使用方法和存储过程一样

create or replace procedure TEST is

cursor c1(pname in varchar2) is

select tname from tab where tname like pname;

pname varchar2(32);

begin

open c1('T%');

loop

fetch c1

into pname;

exit when c1%notfound;

dbms_output.put_line(pname);

end loop;

close c1;

end TEST;

1.2隐式游标

不用明确建立游标变量,分两种:

1.在PL/SQL中使用DML语言,使用ORACLE提供的名为“SQL”的隐示游标。

举例:

declare

begin

update departments set department_name = department_name;

--where 1=2;

dbms_output.put_line('update ' || sql%rowcount || ' records');

end;

/

2.CURSOR FOR LOOP,用于for loop 语句

举例:

例子1:无参数,使用循环,无须打开关闭,本人这种方式

create or replace procedure TEST is

cursor c1 is

select tname from tab;

begin

for rr in c1 loop

dbms_output.put_line(rr.tname);

end loop;

end TEST;

例子1:有参数,使用循环,无须打开关闭,本人这种方式

create or replace procedure TEST is

cursor c1(pname in varchar2) is

select tname from tab where tname like pname;

begin

for rr in c1('T%') loop

dbms_output.put_line(rr.tname);

end loop;

end TEST;

1.3游标常用属性:

%FOUND:变量最后从游标中获取记录的时候,在结果集中找到了记录。

%NOTFOUND:变量最后从游标中获取记录的时候,在结果集中没有找到记录。

%ROWCOUNT:当前时刻已经从游标中获取的记录数量。

%ISOPEN:是否打开。

Declare  /*/* 定义静态游标 */*/

Cursor emps is

Select * from employees where rownum

Emp employees%rowtype;

Row number := 1;

Begin

Open emps; /* ´打开静态游标*/

Fetch emps

into emp; /*读取游标当前行*/

Loop

If emps%found then

Dbms_output.put_line('Looping over record ' || row || ' of ' ||

emps%rowcount);

Fetch emps

into emp;

Row := row + 1;

Elsif emps%notfound then

Exit;

End if;

End loop;

If emps%isopen then

Close emps; /*关闭游标*/

End if;

End;

/

1.4 游标的更新和删除

在PL/SQL中依然可以使用UPDATE和DELETE语句更新或删除数据行。显式游标只有在需要获得多行数据的情况下使用。PL/SQL提供了仅仅使用游标就可以执行删除或更新记录的方法。

UPDATE或DELETE语句中的WHERE CURRENT OF子串专门处理要执行UPDATE或DELETE操作的表中取出的最近的数据。要使用这个方法,在声明游标时必须使用FOR UPDATE子串,当对话使用FOR UPDATE子串打开一个游标时,所有返回集中的数据行都将处于行级(ROW-LEVEL)独占式锁定,其他对象只能查询这些数据行,不能进行UPDATE、DELETE或SELECT...FOR UPDATE操作。

在多表查询中,使用OF子句来锁定特定的表,如果忽略了OF子句,那么所有表中选择的数据行都将被锁定。如果这些数据行已经被其他会话锁定,那么正常情况下ORACLE将等待,直到数据行解锁。

在UPDATE和DELETE中使用WHERE CURRENT OF子串的语法如下:

WHERE{CURRENT OF cursor_name|search_condition}

例:

create or replace procedure pc_SetVersionValid(PFlowsID in integer) is

Cursor c1 is

select *

from wf_flows

where flowname in

(select flowname from wf_flows where flowsid = PFlowsID)

for update;

r c1%rowtype;

v integer;

begin

open c1;

fetch c1

into r;

while c1%found loop

if r.flowsid = PFlowsID then

v := 1;

else

v := 0;

end if;

UPDATE wf_flows SET isValid = v WHERE CURRENT OF c1;

fetch c1

into r;

end loop;

close c1;

commit;

end;

显式和隐式游标的区别:

尽量使用隐式游标,避免编写附加的游标控制代码(声明,打开,获取,关闭),也不需要声明变量来保存从游标中获取的数据。

2、REF CURSOR游标

动态游标,在运行的时候才能确定游标使用的查询。可以分为:

create or replace procedure TEST is

sqlstr varchar2(500);

type RefCur is ref cursor;

c1 refcur;

begin

sqlstr := 'select * from tab';

open c1 for sqlstr;

close c1;

end;

用REF CURSOR实现BULK功能

1. 可以加速INSERT, UPDATE, DELETE语句的执行,也就是用FORALL语句来替代循环语句。

2. 加速SELECT,用BULK COLLECT INTO 来替代INTO。

SQL> create table tab2  as select empno ID, ename NAME, sal SALARY from emp where 1=2;

create or replace procedure REF_BULK is

/*  定义复杂类型 */

type empcurtyp  is ref cursor;

type idlist  is table of emp.empno%type;

type namelist  is table of emp.ename%type;

type sallist  is table of emp.sal%type;

/* 定义变量  */

emp_cv  empcurtyp;

ids  idlist;

names namelist;

sals sallist;

row_cnt number;

begin

open emp_cv for select empno, ename, sal from emp;

fetch emp_cv  BULK COLLECT  INTO ids, names, sals;

--将字段成批放入变量中,此时变量是一个集合

close emp_cv;

for i in ids.first .. ids.last loop

dbms_output.put_line(' || ids(i) || ' || names(i) ||' salary=' || sals(i));

end loop;

FORALL  i  IN  ids.first .. ids.last

insert into tab2 values (ids(i), names(i), sals(i));

commit;

select count(*) into row_cnt from tab2;

dbms_output.put_line('-----------------------------------');

dbms_output.put_line('The row number of tab2 is ' || row_cnt);

end REF_BULK;

3、cursor和ref cursor的区别

从技术底层看,两者是相同的。普通plsql cursor在定义时是“静态”的。而

Ref cursors可以动态打开。

例如下面例子:

Declare

type rc is ref cursor;

cursor c is select * from dual;

l_cursor rc;

begin

if ( to_char(sysdate,'dd') = 30 ) then

open l_cursor for 'select * from emp';

elsif ( to_char(sysdate,'dd') = 29 ) then

open l_cursor for select * from dept;

else

open l_cursor for select * from dual;

end if;

open c;

end;

/

rc根据逻辑动态打开;而游标c定义好了只有就无法修改了。

ref cursor可以返回给客户端,cursor则不行。

cursor可以是全局的global ,ref cursor则必须定义在过程或函数中。

ref cursor可以在子程序间传递,cursor则不行。

cursor中定义的静态sql比ref cursor效率高,所以ref cursor通常用在:向客户端返回结果集。

cursor java_ORACLE中的游标Cursor总结相关推荐

  1. oracle用游标drop多个表,Oracle Procedure中使用游标cursor更新多表?

    Oracle中写Procedure一直是Oracle开发中比较复杂的地方,但是掌握procedure 和cursor将使得你在Oracle开发中如鱼的水,真正体会Oracle的强大.下面通过我自己写的 ...

  2. oracle中的cursor属性有哪些,Oracle学习11:游标(cursor)--显式游标隐式游标、游标四个属性、循环遍历...

    1.概述 上文PLSQL学习中提到的知识,可以发现,基本都可以通过Java等语言实现,而为了实现程序的可移植性,实际开发工作中我们也是如此做的. 那么PLSQL的重点是什么呢?接下来我们来介绍游标cu ...

  3. Oracle中游标Cursor介绍

    转自:http://zohan.group.iteye.com/group/wiki/2278-cursor Oracle中游标Cursor介绍 一  概念 游标是SQL的一个内存工作区,由系统或用户 ...

  4. Oracle中游标Cursor基本用法详解

    这篇文章主要介绍了Oracle中游标Cursor基本用法详解,还是比较全面的,具有一定参考价值,需要的朋友可以了解下. 查询 SELECT语句用于从数据库中查询数据,当在PL/SQL中使用SELECT ...

  5. SQL游标(cursor)详细说明及内部循环使用示例

    游标 游标(cursor)是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果.每个游标区都有一个名字,用户可以用SQL语句逐一从游标中获取记录,并赋给主变量,交由主语言进一步处理. 游标是处理 ...

  6. oracle is ref cursor java_oracle cursor 用法总结

    PL sql中cursor用法是非常广泛的,常常用于存储过程和函数的返回值,其中用于函数的返回值变相的解决了pl sql 没有表值函数的问题,一般的,在java 调用存储过程,所返回的结果集也是用游标 ...

  7. SQL Server 数据库的维护(四)__游标(cursor)

    --维护数据库-- --游标(cursor)-- --概述: 注:使用select语句查询结果的结果集是一个整体,如果想每次处理一行或一部分行数据,游标可以提供这种处理机制.可以将游标理解为指针.指针 ...

  8. SQL SERVER 参考:游标(Cursor)的讲解与实例

    在数据库中,游标是一个十分重要的概念.游标提供了一种对从表中检索出的数据进行操作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制.游标总是与一条T_SQL ...

  9. 游标cursor,游标循环和记录变量的定义

    1.游标 游标使用分为四步骤. a.声明游标 cursor 游标名(参数1 数据类型[,参数2 数据类型]) b.打开游标 open 游标名[(实际参数1[,实际参数2.........])]: c. ...

最新文章

  1. ATS名词术语(待续)
  2. JAVA匿名内部类的一点讨论
  3. 你知道标志着团队已经敏捷化的8个信号吗?
  4. 求 1 到 n 的所有数的约数和
  5. php 图像 处理,PHP 处理图像步骤解析
  6. Build a Machine Learning Portfolio(构建机器学习投资组合)
  7. linux 卸载ninja,Linux下数据库管理工具:DbNinja
  8. linux下c语言获取系统时间
  9. 二、2.4版本之前的apache的安装
  10. php 处理eml,PHP读取、解析eml文件及生成网页详解
  11. 【官宣】.NET 6 正式版来了
  12. MySQL小白快速入门笔记
  13. thinkpad X1 2016 NMV固态硬盘 win7+win10双系统 GPT+UEFI启动 系统安装记录
  14. 一文读懂设计模式--策略模式
  15. 1100 Mars Numbers (20分)
  16. 【luogu P7473】重力球
  17. java二次开发微信公众号授权
  18. 【头歌】求解n皇后问题
  19. 云计算与大数据技术应用 第一章
  20. 你在用什么英文搜索引擎

热门文章

  1. 智能楼宇智慧建筑3d可视化技术,实现对楼宇建筑园区等的加持-小水智能
  2. linux命令行使用ppt,linux图形界面与命令行.ppt
  3. java中的输入scanner_java中如何输入一个数,用scanner语句
  4. ArcGIS API for Flex 调用天地图、e都市瓦片地图
  5. java replace stringbuilder_2020年最新java面试题库(部分)
  6. 90%的自媒体达人都在用的文案模板
  7. php中db是指什么意思,phpmyadmin的作用是什么意思_数据库
  8. python数据清洗实例_hive 的日志处理统计网站的 PV 、UV案例 与 给合 python的数据清洗数据案例...
  9. Redmine使用说明,比较详细并且有具体使用简单使用制度
  10. 图片压缩、裁剪、GIF制作的最佳工具!