Cursor的基本使用方法

今天在用到Cursor的时候发现,有很多游标相关的知识还是有欠缺,在网上搜了篇基础讲解的文,觉得还不错,自己整理了一下发上来。虽然很基础,但是有一些内容之前确实没有很扎实得掌握,所以记下来也可以加深一下印象。

一、Cursor的分类

二、各类Cursor举例

----

静态游标

-

显式游标

set

serveroutput

on

declare

cursor

emp_sor(emp_deptno

in

number

)

is

select

*

from

emp

where

deptno=emp_deptno ;

emp_i emp%

rowtype

;

begin

dbms_output.put_line(

'Getting emp from deptno 10'

);

open

emp_sor(

10

);

loop

fetch

emp_sor

into

emp_i;

exit

when

emp_sor%

notfound

;

dbms_output.put_line(

'Employee id '

||emp_i.empno||

' is:'

);

dbms_output.put_line(emp_i.ename);

end

loop

;

close

emp_sor;

end

;

/

----

静态游标

-

隐式游标

-1.DML

begin

update

emp

set

ename=ename ;

--where 1=2;

dbms_output.put_line(

'update '

||

sql

%

rowcount

||

' records'

);

end

;

/

----

静态游标

-

隐式游标

-2.loop for

begin

for

r_sor

in

(

select

empno,ename

from

emp)

loop

dbms_output.put_line(r_sor.empno ||

' : '

|| r_sor.ename);

end

loop

;

end

;

/

----

静态游标

-

隐式游标

-3.select into

declare

v

varchar2

(

20

);

begin

select

ename

into

v

from

emp

where

rownum =

1

;

dbms_output.put_line(v);

dbms_output.put_line(

sql

%

rowcount

);

end

;

/

----

动态游标

-

弱类型

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'

;-- ref cursor with dynamic sql

elsif

(to_char(

sysdate

,

'dd'

) =

29

)

then

open

l_cursor

for

select

*

from

dept;-- ref cursor with static sql

else

open

l_cursor

for

select

*

from

dual;-- with ref cursor with static sql

end

if

;

open

c;-- the "normal" static cursor

end

;

/

----

动态游标

-

强类型

declare

type

emp_job

is

record

(empno

number

,

ename

varchar2

(

20

),

job

varchar2

(

30

)

);

type

emp_refcur

is

ref

cursor

return

emp_job;

--

声明

REF CURSOR

emp_sor emp_refcur;

emp_iemp_job;

begin

open

emp_sor

for

select

empno,ename,job

from

emp

where

rownum <

10

order

by

1

;

loop

fetch

emp_sor

into

emp_i;

exit

when

emp_sor%

notfound

;

dbms_output.put_line(emp_i.ename ||

'''s job is :'

);

dbms_output.put_line(emp_i.job);

end

loop

;

close

emp_sor;

end

;

/

普通cursor与REF cursor的区别:

1)静态cursor不能返回到客户端,只有PL/SQL才能利用它。refcursor能够被返回到客户端,这就是从Oracle的存储过程返回结果集的方式。

2)静态cursor可以是全局的,而refcursor则不是。

3)refcursor可以从子例程传递到子例程,而cursor则不能。为了共享静态cursor,必须在包说明或包体中把它定义为全局cursor。

因为使用全局变量通常不是一种很好的编码习惯,因此可以用refcursor来共享PL/SQL中的cursor,无需混合使用全局变量。

4)使用静态cursor,通过静态SQL(但不用refcursor),比使用refcursor效率高,而refcursor的使用仅限于以下几种情况:

1.把结果集返回给客户端;

2.在多个子例程之间共享cursor(实际上与上面提到的一点非常类似);

3.没有其他有效的方法来达到你的目标时,则使用refcursor,正如必须用动态SQL时那样

----

动态游标

-sys_refcursor

DECLARE

TYPE

mytable

IS

TABLE

OF

emp%

ROWTYPE

;

l_data mytable;

l_refc

sys_refcursor

;

BEGIN

OPEN

l_refc

FOR

SELECT

empno,ename,job,mgr,hiredate,sal,comm,deptno

FROM

emp;

FETCH

l_refc

BULK

COLLECT

INTO

l_data;

CLOSE

l_refc;

FOR

i

IN

1

.. l_data.COUNT

LOOP

DBMS_OUTPUT.put_line ( l_data(i).ename ||

' was hired since '

|| l_data (i).hiredate );

END

LOOP

;

END

;

非强类型的Ref cursor 和sys_refcursor的区别:

A REF CURSOR that does not specify the return type such as SYS_REFCURSOR. Meaning the SYS_REFCURSOR can be opened for a dynamic SQL query, where as simple REF CURSOR can not be opened for a query dynamically built at execution time.

三、游标属性

/*************************************************************

游标属性:

%FOUND

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

%NOTFOUND

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

%ROWCOUNT

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

%ISOPEN

:是否打开。

**************************************************************/

----

静态游标

-

游标属性

Declare

Cursor

emp_sor

is

Select

*

from

emp

where

rownum<

6

order

by

1

;

emp_i emp%

rowtype

;

num

number

:=

1

;

Begin

Open

emp_sor;

Fetch

emp_sor

into

emp_i;

Loop

If

emp_sor%

found

then

Dbms_output.put_line(

'Looping over record '

||num||

' of '

|| emp_sor%

rowcount

);

Fetch

emp_sor

into

emp_i;

num := num +

1

;

Elsif

emp_sor%

notfound

then

Exit

;

---exit loop, not IF

End

if

;

End

loop

;

If

emp_sor%

isopen

then

Close

emp_sor;

End

if

;

End

;

/

cursor用法java,Cursor的基本使用方法相关推荐

  1. python中scroll的用法_python cursor中的scroll方法

    scroll(self, value, mode='relative'):移动指针到某一行.如果mode='relative',则表示从当前所在行移动value条,如果 mode='absolute' ...

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

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

  3. java8 stream reduce 方法用法 java stream reduce 方法使用方法

    java8 stream reduce 方法用法 java stream reduce 方法使用方法 一.背景 在使用Stream的reduce方法时,发现该方法有 3个重载方法,分别是: 一个参数. ...

  4. java filefilter的用法_Java File.listFiles(FileFilter filter)方法

    Java Java File.listFiles(FileFilter filter)方法具有以下语法. public File [] listFiles(FileFilter filter) 示例 ...

  5. android cursor 空,java – Android:即使数据库不为空,Cursor也总是返回null

    即使数据库不为空,Cursor也始终返回null.为什么?以及如何解决?谢谢. public StatParcours getOneUserInfo(int id) { SQLiteDatabase ...

  6. Java读取文件为字符串方法

    Java读取文件为字符串方法 方法一:使用Files工具类 java.nio.file.Files工具类,不依赖三方组件 Path.of方法在jdk11才支持 public String fileTo ...

  7. java多线程中的join方法详解

    java多线程中的join方法详解 方法Join是干啥用的? 简单回答,同步,如何同步? 怎么实现的? 下面将逐个回答. 自从接触Java多线程,一直对Join理解不了.JDK是这样说的:join p ...

  8. java能否访问PHP的服务器,PHP与Java进行通信的实现方法

    缘起: 最近做了一个电商平台与网银整合的小东西,程序是开源的 Ecmall的,网银的接口也很规范,给出的文档很全,唯一的小问题是,网银使用的签名和验签的lib是只有java和c的,对java还熟悉一些 ...

  9. Shell-通过shell启动Java类中的main方法 + 通过Shell启动jar包

    文章目录 概述 shell启动Java类中的main方法 启动脚本分析 启动脚本 shell启动jar包 概述 Java程序 运行在linux主机上, 通过shell脚本启动为进程. Java程序中 ...

最新文章

  1. Waymo的激光雷达计划:进展如何?
  2. php清除账号登录,php实现账号登录/上传/下载/删除文件
  3. 《C++ primer》--第三章
  4. VS2005在编译项目时找不到Ceplatform和PLATFORMDEFINE变量
  5. AspectJ对AOP的实现
  6. 11个好用到起飞的「Python字典」知识点!
  7. .NET简谈组件程序设计之(上下文与同步域)
  8. object-c 入门基础篇
  9. 基于JAVA+SpringMVC+Mybatis+MYSQL的大学生考勤管理系统及智能分析系统
  10. Linux下解决高并发socket最大连接数限制,tcp默认1024个连接
  11. php如何安装源码包,php源码包安装步骤是什么
  12. PWA--未来式app
  13. unix 与 linux 操作系统 介绍
  14. 什么是软件实施?软件实施前景几何?软件实施的面试题有那些?
  15. Linux——vi命令详解
  16. Hadoop(一) Centos7 下Hdoop 安装及伪分布式集群部署
  17. Protobuf 介绍与实战21:如何生成一维数组、二维数组(repeated数组类型介绍)
  18. Python与Anaconda、Jupyter Notebook与Pycharm
  19. 对vue与angular和react的对比
  20. 汽车计算机控制的电路有哪些特点,在电磁继电器工作电路中的电压和电流比起控制电路来说一般是...

热门文章

  1. 17--合并两个有序数组
  2. 学成在线--0.项目概述
  3. redis 队列_Redis与Rabbitmq消息队列的区别
  4. STM32串口通信中使用printf发送数据配置方法 开发环境 Keil
  5. iOS关于armv7,armv7s,arm64,i386,x86_64等问题
  6. linux sql语句传参数,Linux/Unixshell参数传递到SQL脚本
  7. eigen 列向量转矩阵_快速入门矩阵运算——开源库Eigen
  8. 全国计算机vb考试经典程序设计,全国计算机二级《VB语言程序设计》考试要点...
  9. 金山云服务器内网带宽,金山云-文档中心-配置弹性网卡
  10. html里嵌入语音,HTML5语音合成API语音/语言支持