分享
 
 
 

关于在PL/SQL中使用正确的循环控制

王朝mssql·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

当你在 PL/SQL 中处理一个被索引的表时,很多情况下你不能确定表上是否存在索引,所以你不能使用最明显的 FOR 循环方式来循环表中的值。例如:

Declare

type my list_type is table of number index by pls_integer;

mylist mylist_type;

begin

-- start at 2, instead of 1

mylist(2) := 2;

mylist(3) := 3;

-- skip 4 and 5

mylist(6) := 6;

for i in 1..mylist.count loop

dbms_output.put_line(mylist(i));

end loop;

end;

/

前面的代码将返回 ORA-01403 错误:由于缺少索引1,没有发现数据。

如果你尝试使用 .FIRST/.LAST 修正这个问题,那么你将自动地从第一个索引开始循环,直到到达最后一个索引,如下:

Declare

type mylist_type is table of number index by pls_integer;

mylist mylist_type;

begin

mylist(2) := 2;

mylist(3) := 3;

mylist(5) := 6;

for i in mylist.first .. mylist.last loop

dbms_output.put_lin(mylist(i));

end loop;

end;

/

然而,你依然得到一个 ORA-01403 错误:由于跳过值,没有发现数据。要进一步避免这种错误,你可以在访问索引前使用 EXISTS 方法测试它是否存在:

Declare

type mylist_type is table of number index by pls_integer;

mylist mylist_type;

begin

mylist(2) := 2;

mylist(3) := 3;

mylist(6) := 6;

for i in mylist.first..mylist.last loop

if (mylist.exists(i)) then

dbms_output.put_line(mylist(i));

end if;

end loop;

end;

/

或者,你可以通过.NEXT 属性使用常规的 LOOP 循环来迭代一个表上存在的索引――但是你必须声明循环计数器:

Declare

type mylist_type is table of number index by pls_integer;

mylist mylist_type;

i pls_integer;

begin

mylist(2) := 2;

mylist(3) := 3;

mylist(6) := 6;

i := mylist.first;

loop

dbms_output.put_line(mylist(i));

exit when i = mylist.last;

i := mylist.next(i);

end loop;

end;

/

当你不确定哪些值已经被删除或装载而导致缺少索引时,可以使用上面这两个有效的方法作为默认方法。但是对于使用 FORALL 语句的大量操作,这两种方法都不能正确运行,原因是 FORALL 语句并不是一个真正的循环,而且其语法只能带一个下加界,一个上边界和一个 SQL DML 语句。

然而,Oracle 10g中引入了两个新子句,这两个子句允许你避免这种局限性。向 FORALL 语法添加一个 INDICES OF 子句允许你自动地循环一个表中的所有值,而无须担心索引是否存在:

Declare

type mylist_type is table of number index by pls_integer;

mylist mylist_type;

begin

mylist(2) := 2;

mylist(3) := 3;

mylist(6) := 6;

foralli in indices of mylist

insert into mynumtable values(mylist(i));

end;

/

另外还有一个 VALUES OF 子句,该子句使用你的嵌套表的值,或者被表索引的值作为循环的下标:

Declare

type mysubs_type is table of pls_integer index by pls_integer;

type mylist_type is table of number index by pls_integer;

mysubs mylist_type;

mylist mylist_type;

begin

mylist(2) := 2;

mysubs(10) := 2;

-- point to mylist(2)

mylist(3) := 3;

mysubs(20) := 3;

-- point to mylist(3)

mylist(6) := 6;

mysubs(30) := 6;

-- point to mylist(6)

mysubs(40) := 3;

-- point to mylist(3), again!

foralli in values ofmysubs

insert into mynumtable values(mylist(i));

end;

/

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有