大神,怎么获得oracle游标中的多行数据

大神,怎么获得oracle游标中的多行数据,第1张

用table():

create or replace type t_test as object(id integer,rq date,mc varchar2(60));

create or replace type t_test_table as table of t_test;

create or replace function f_test_array(n in number default null) return t_test_tableas v_test t_test_table := t_test_table();beginfor i in 1  nvl(n,100) loopv_testextend();v_test(v_testcount) := t_test(i,sysdate,'mc'||i);end loop;return v_test;end f_test_array;/

select  from table(f_test_array(10));

select  from the(select f_test_array(10) from dual);

varno VARCHAR2(20);

varprice VARCHAR2(20);的CURSOR mycur(VARTYPE数)

选择“EMP_NO,”emp_zc cus_emp_basic

其中com_no = VARTYPE

开始

,如果mycur%ISOPEN = false,那么

:开放mycur(043925);

结束的话;

取mycur到varno,varprice,;

而mycur%,符合

循环

DBMS_OUTPUTPUT_LINE(varno | |','| | varprice);

,如果mycur%ROWCOUNT = 2,那么

退出;

结束,如果

取mycur;到varno varprice

结束循环;

密切mycur;

结束;

记录不会被保存在数据库中,它是记录中的变量来节省内存空间,我们必须先定义记录结构,然后声明一个记录变量。 PL / SQL记录用户定义的数据类型。

Oracle游标分为显示游标和隐式游标

显示游标(Explicit Cursor):在PL/SQL程序中定义的 用于查询的游标称作显示游标

隐式游标(Implicit Cursor):是指非PL/SQL程序中定义的 而且是在PL/SQL中使用UPDATE/DELETE语句时 Oracle系统自动分配的游标

一 显示游标

使用步骤

( )定义 ( )打开 ( )使用 ( )关闭

使用演示

首先创建测试用表STUDENT 脚本如下

( ) 使用WHILE循环处理游标

create or replace PROCEDURE PROC_STU AS

BEGIN

显示游标使用 使用while循环

declare

定义游标 名称为cur_stu

cursor cur_stu is

select stuno stuname from student order by stuno;

定义变量 存放游标取出的数据

v_stuno varchar( );

v_stuname varchar( );

begin

打开游标cur_stu

open cur_stu;

将游标的当前行取出存放到变量中

fetch cur_stu into v_stuno v_stuname;

while cur_stu%found 游标所指还有数据行 则继续循环

loop

打印结果

dbms_output PUT_LINE(v_stuno|| > ||v_stuname);

继续将游标所指的当前行取出放到变量中

fetch cur_stu into v_stuno v_stuname;

end loop;

close cur_stu; 关闭游标

end;

END PROC_STU ;

( ) 使用IF ELSE代替WHILE循环处理游标

create or replace PROCEDURE PROC_STU AS

BEGIN

显示游标使用 使用if判断

declare

定义游标 名称为cur_stu

cursor cur_stu is

select stuno stuname from student order by stuno;

定义变量 存放游标取出的数据

v_stuno varchar( );

v_stuname varchar( );

begin

打开游标cur_stu

open cur_stu;

将游标的当前行取出存放到变量中

fetch cur_stu into v_stuno v_stuname;

loop

if cur_stu%found then 如果游标cur_stu所指还有数据行

打印结果

dbms_output PUT_LINE(v_stuno|| > ||v_stuname);

继续将游标所指的当前行取出放到变量中

fetch cur_stu into v_stuno v_stuname;

else

exit;

end if;

end loop;

close cur_stu; 关闭游标

end;

END PROC_STU ;

( ) 使用FOR循环处理游标

create or replace PROCEDURE PROC_STU AS

BEGIN

显示游标使用 使用for循环

declare

定义游标 名称为cur_stu

cursor cur_stu is

select stuno stuname from student order by stuno;

begin

for stu in cur_stu

loop

dbms_output PUT_LINE(stu stuno|| > ||stu stuname);

循环做隐含检查 %notfound

end loop;

自动关闭游标

end;

END PROC_STU ;

( ) 常用的使用EXIT WHEN处理游标

create or replace

PROCEDURE PROC_STU _ AS

BEGIN

显示游标使用 使用exit when循环

declare

定义游标 名称为cur_stu

cursor cur_stu is

select stuno stuname from student order by stuno;

定义变量 存放游标取出的数据

v_stuno varchar( );

v_stuname varchar( );

begin

打开游标cur_stu

open cur_stu;

loop

将游标的当前行取出存放到变量中

fetch cur_stu into v_stuno v_stuname;

exit when cur_stu%notfound; 游标所指还有数据行 则继续循环

打印结果

dbms_output PUT_LINE(v_stuno|| > ||v_stuname);

end loop;

close cur_stu; 关闭游标

end;

END PROC_STU _ ;

二 隐式游标

使用演示

create or replace PROCEDURE PROC_STU AS

BEGIN

隐式游标使用

update student set stuname= 张燕广 where stuno= ;

如果更新没有匹配则插入一条新记录

if SQL%NOTFOUND then

insert into student(STUNO STUNAME AGE GENDER)

values( 张燕广 男 );

end if;

END PROC_STU ;

说明

所有的SQL语句在上下文区内部都是可执行的 因为都有一个游标指向上下文区 此游标就是

SQL游标 与现实游标不同的是 SQL游标在PL/SQL中不需要打开和关闭 而是在执行UPDATE

DELETE是自动打开和关闭

上面例子中就是通过SQL%NOTFOUND游标属性判断UPDATE语句的执行结果决定是否需要插入新记录 CREATE TABLE STUDENT (

STUNAME VARCHAR ( BYTE)

STUNO VARCHAR ( BYTE)

AGE NUMBER

GENDER VARCHAR ( CHAR)

lishixinzhi/Article/program/Oracle/201311/17531

以上就是关于大神,怎么获得oracle游标中的多行数据全部的内容,包括:大神,怎么获得oracle游标中的多行数据、游标的列名是动态的,怎么获取游标的列值(oracle 数据库)、Oracle游标使用总结等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/9561057.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-29
下一篇2023-04-29

发表评论

登录后才能评论

评论列表(0条)

    保存