Welcome 微信登录

首页 / 数据库 / MySQL / Oracle 11g Release 1 (11.1) PL/SQL_多维 Collection 类型和其异常

本文内容

  • 多维 Collection
  • Collection 异常
多维 Collection虽然 collection 只有一维的,但可以模型一个多维的。创建一个 collection,其每个元素也是 collection 。例如,创建一个 varraynested table,一个 varrayvarray,一个 nested tablevarray 等。 示例1:演示多维 varrayDECLARETYPE t1 IS VARRAY(10) OF INTEGER;TYPE nt1 IS VARRAY(10) OF t1; -- multilevel varray typeva t1 := t1(2,3,5);-- initialize multilevel varraynva nt1 := nt1(va, t1(55,6,73), t1(2,4), va);i INTEGER;va1 t1;BEGIN-- multilevel accessi := nva(2)(3); -- i will get value 73DBMS_OUTPUT.PUT_LINE("I = " || i);-- add a new varray element to nvanva.EXTEND;-- replace inner varray elementsnva(5) := t1(56, 32);nva(4) := t1(45,43,67,43345);-- replace an inner integer elementnva(4)(4) := 1; -- replaces 43345 with 1-- add a new element to the 4th varray element-- and store integer 89 into it.nva(4).EXTEND;nva(4)(5) := 89;END;/示例2:演示多维 nested table DECLARETYPE tb1 IS TABLE OF VARCHAR2(20);TYPE Ntb1 IS TABLE OF tb1; -- table of table elementsTYPE Tv1 IS VARRAY(10) OF INTEGER;TYPE ntb2 IS TABLE OF tv1; -- table of varray elementsvtb1 tb1 := tb1("one", "three");vntb1 ntb1 := ntb1(vtb1);vntb2 ntb2 := ntb2(tv1(3,5), tv1(5,7,3));-- table of varray elementsBEGINvntb1.EXTEND;vntb1(2) := vntb1(1);-- delete the first element in vntb1vntb1.DELETE(1);-- delete the first string-- from the second table in the nested tablevntb1(2).DELETE(1);END;/示例3:演示多维 associative array DECLARETYPE tb1 IS TABLE OF INTEGER INDEX BY PLS_INTEGER;-- the following is index-by table of index-by tablesTYPE ntb1 IS TABLE OF tb1 INDEX BY PLS_INTEGER;TYPE va1 IS VARRAY(10) OF VARCHAR2(20);-- the following is index-by table of varray elementsTYPE ntb2 IS TABLE OF va1 INDEX BY PLS_INTEGER;v1 va1 := va1("hello", "world");v2 ntb1;v3 ntb2;v4 tb1;v5 tb1; -- empty tableBEGINv4(1) := 34;v4(2) := 46456;v4(456) := 343;v2(23) := v4;v3(34) := va1(33, 456, 656, 343);-- assign an empty table to v2(35) and try againv2(35) := v5;v2(35)(2) := 78; -- it works nowEND;/ 
  • 1
  • 2
  • 下一页
Oracle 11g Release 1 (11.1) PL/SQL_了解静态和动态 SQLOracle EBS各个模块日志收集的方法相关资讯      Oracle存储过程 
  • Oracle存储过程拼接in语句 & 自定  (今 09:21)
  • 【PL/SQL系列】Oracle存储过程使用  (04月23日)
  • Oracle存储过程及Java调用  (05/28/2015 20:29:33)
  • Java调用Oracle存储过程返回多条结  (04月29日)
  • Oracle中的存储过程简单应用  (04月10日)
  • 判断点是否落在面中的Oracle存储过  (05/09/2015 09:39:30)
本文评论 查看全部评论 (0)
表情: 姓名: 字数


评论声明
    版权所有©石家庄振强科技有限公司2024 冀ICP备08103738号-5 网站地图