存储过程游标使用

1)从表中读取数据(查看表中一共有多少条数据)
方式一:
create or replace procedure calledproc is
a number(38);
cursor selec_cur is select A from test;–定义一个静态sql游标
begin
open selec_cur;
loop
fetch selec_cur into a; –每次循环取到一个变量输入到b中
exit when selec_cur%notfound; –处理例外情况,当游标未读取导数据时,即退出
DBMS_OUTPUT.PUT_line(a);
end loop;
close celec_cur;
end;
方式二:
create or replace procedure testproc is
cursor cur_test is select A from test;
v_testa test.A%type; –定义一个变量,用来读取test表中的a字段。
begin
open cur_type;
loop
fetch cur_test into v_testa;
exit when cur_test%notfouond ;
dbms_output.put_line(v_testa.A);
end loop;
end;
方式三:
create or replace procedure testproc is
cursor cur_test is select A from test;
begin
for rec_test in cur_test loop –rec_test直接使用,不需要定义,此处直接将cur_test当做一个结果集来处理
dbms_output.put_line(rec_test.A);
end loop;
end;
动态游标:
create or replace procedure testproc is
type cur_type is ref cursor;–定义一个动态游标类型cur_type
cur_policy cur_type;
sqlStr varchar2(2000);
rec_policy test.A%rowtype;
begin
sqlStr:=’select A from test’;
open cur_policy for sqlStr;
loop
fetch cur_policy into rec_policy.A;
exit when cur_policy%notfound;
dbms_output.put_line(rec_policy.A);

end loop;
close cur_policy;
end ;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 存储过程中可以使用游标来处理结果集。游标是一种指向结果集的命名数据结构,可以通过游标来访问结果集中的数据行。下面是一个简单的示例,演示了如何在 Oracle 存储过程使用游标。 ```sql CREATE OR REPLACE PROCEDURE my_proc IS -- 声明游标类型 CURSOR my_cursor IS SELECT column1, column2, column3 FROM my_table WHERE column4 = 'some condition'; -- 声明游标返回的数据类型 TYPE my_cursor_type IS RECORD ( column1 my_table.column1%TYPE, column2 my_table.column2%TYPE, column3 my_table.column3%TYPE ); -- 声明变量来存储游标返回的数据 my_data my_cursor_type; BEGIN -- 打开游标 OPEN my_cursor; -- 循环遍历游标返回的结果集 LOOP -- 获取下一行数据 FETCH my_cursor INTO my_data; -- 判断是否还有数据 EXIT WHEN my_cursor%NOTFOUND; -- 处理游标返回的数据 -- ... END LOOP; -- 关闭游标 CLOSE my_cursor; END; ``` 在这个示例中,我们首先声明了一个游标类型 `my_cursor`,并且定义了游标返回的数据类型 `my_cursor_type`。然后我们声明了一个变量 `my_data`,用来存储游标返回的数据。 在存储过程主体中,我们首先打开游标 `my_cursor`,然后使用 `LOOP` 循环遍历游标返回的结果集。在循环体中,我们使用 `FETCH` 语句获取下一行数据,并且判断是否还有数据。如果没有数据了,我们使用 `EXIT` 语句退出循环。否则,我们可以处理游标返回的数据,比如将其插入到另外一个表中。最后,我们关闭游标 `my_cursor`,释放资源。 需要注意的是,在存储过程使用游标可能会影响性能,特别是当处理大量数据时。因此,我们应该尽可能地使用 SQL 查询语句来处理结果集,而不是使用游标

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值