PL/SQL变长数组是PL/SQL集合数据类型中的一种,其使用方法与PL/SQL嵌套表大同小异,唯一的区别则是变长数组的元素的最大个数是有限制的。也即是说变长数组的下标固定下限等于1,上限可以扩展。下面给出具体的描述及其使用方法。

一、变长数组语法

//type_name 用于指定varray类型名,size_limit 定义varray元素的最大个数,element_type用于指定元素的数据类型 
TYPE type_name IS {VARRAY | VARYING ARRAY} (size_limit) OF element_type [NOT NULL];
varray_name TYPE_NAME;   //varray_name 用于定义varray变量

二、变长数组特性

变长数组主要的特性即是元素的最大个数是有限制 变长数组下标固定为1,上限可以扩展与嵌套表类似,在变长数组声明时自动设置为NULL值.所谓的空值指的是集合本身是空,不是针对它所拥有的元素故在元素引用前需要对其进行初始化.

三、变长数组示例

--1、声明变长数组,并输出其结果 
scott@CNMMBO> DECLARE 
  2     CURSOR name_cur IS 
  3     SELECT dname 
  4     FROM   dept 
  5     WHERE  deptno < 40; 
  6     //声明一个包含10个元素的变长数组,且且数据类型为dept.dname类型
  7     TYPE name_type IS VARRAY( 10 ) OF dept.dname%TYPE;   
  8     //初始化变长数组
  9     varray_dname_tab   name_type := name_type( );        
 10     v_counter INTEGER := 0;    
 11  BEGIN 
 12     FOR name_rec IN name_cur 
 13     LOOP 
 14          v_counter   := 
 15          v_counter 
 16          + 1; 
 17          varray_dname_tab.EXTEND;         //使用extend进行扩展   
 18          varray_dname_tab( v_counter ) := name_rec.dname;  //按下标输出变长数组的所有元素 
 19          DBMS_OUTPUT.put_line(   'Dname (' 
 20          || v_counter 
 21          || ') is :' 
 22          || varray_dname_tab( v_counter ) ); 
 23     END LOOP; 
 24  END; 
 25  / 
Dname (1) is :ACCOUNTING 
Dname (2) is :RESEARCH 
Dname (3) is :SALES      
 
--2、对变长数组直接赋初值,且使用count遍历并输出所有元素
scott@CNMMBO> DECLARE 
  2     TYPE name_type IS VARRAY( 2 ) OF VARCHAR2( 10 ); 
  3   
  4     varray_name_tab   name_type := name_type( 'Robinson', 'Jackson' ); //此处对varray_name_tab初始化并赋初值 
  5  BEGIN 
  6     FOR i IN 1 .. varray_name_tab.COUNT       //使用count来遍历并输出变长数组的所有元素 
  7     LOOP 
  8DBMS_OUTPUT.put_line(   'Name varray_name_tab( ' 
  9   || i 
 10   || ' ) is : ' 
 11   || varray_name_tab( i ) ); 
 12     END LOOP; 
 13  END; 
 14  / 
Name varray_name_tab( 1 ) is : Robinson 
Name varray_name_tab( 2 ) is : Jackson 
PL/SQL procedure successfully completed. 
 
--3、超出变长数组大小的情形 
scott@CNMMBO> DECLARE 
  2     TYPE name_type IS VARRAY( 2 ) OF VARCHAR2( 10 ); 
  3   
  4     varray_name_tab   name_type := name_type( 'Robinson', 'Jackson' ); 
  5  BEGIN 
  6     FOR i IN 1 .. varray_name_tab.COUNT 
  7     LOOP 
  8DBMS_OUTPUT.put_line(   'Name varray_name_tab( ' 
  9   || i 
 10   || ' ) is : ' 
 11   || varray_name_tab( i ) ); 
 12     END LOOP; 
 13   
 14     varray_name_tab.EXTEND; 
 15     varray_name_tab( 3 ) := 'Johnson'; 
 16     DBMS_OUTPUT.put_line( 'Name varray_name_tab (3) is ' 
 17|| varray_name_tab( 3 ) ); 
 18  END; 
 19  / 
Name varray_name_tab( 1 ) is : Robinson 
Name varray_name_tab( 2 ) is : Jackson 
DECLARE 

ERROR at line 1: 
ORA-06532: Subscript outside of limit 
ORA-06512: at line 14 
 
--4、存储变长数组到数据库及修改变长数组 
scott@CNMMBO> CREATE OR REPLACE TYPE varray_phone IS VARRAY( 2 ) OF VARCHAR2( 40 ); //创建变长数组类型 
  2  / 
Type created. 
 
scott@CNMMBO> CREATE TABLE tb_emp 
  2  ( 
  3     empno   NUMBER( 4 ) 
  4   , ename   VARCHAR2( 10 ) 
  5   , phone   varray_phone  //列phone使用到了变长数组 
  6  ) 
  7  ; 
 
Table created. 
--插入新记录到变长数组 
scott@CNMMBO> insert into tb_emp select 6666,'Robinson',varray_phone('13423456789','075520123650') from dual; 
1 row created. 
scott@CNMMBO> insert into tb_emp select 7777,'Jackson',varray_phone('13423456789','075520123650') from dual; 
1 row created. 
scott@CNMMBO> commit; 
Commit complete. 
 
scott@CNMMBO> col phone format a25 
scott@CNMMBO> select * from tb_emp;  //查看插入的记录 
     EMPNO ENAME      PHONE 
---------- ---------- ------------------------- 
      6666 Robinson   VARRAY_PHONE('13423456789', '075520123650') 
      7777 Jackson    VARRAY_PHONE('13423456789', '075520123650') 
 
-->插入变长数组包含3个元素的记录,此时提示超出了变长数组范围 
scott@CNMMBO> insert into tb_emp select 8888,'Johnson',varray_phone('13423456789','075520123650','010123')
  2  from dual; 
insert into tb_emp select 8888,'Johnson',varray_phone('13423456789','075520123650','010123') 
     * 
ERROR at line 1: 
ORA-22909: exceeded maximum VARRAY limit 
 
-->修改变长数组长度范围限制到3,且使用cascade,即及联修改到表tb_emp 
scott@CNMMBO> alter type varray_phone modify limit 3 cascade;   
Type altered. 
 
-->再次插入数据成功 
scott@CNMMBO> insert into tb_emp select 8888,'Johnson',varray_phone('13423456789','075520123650','010123') 
  2  from dual; 
1 row created. 
 
-->插入变长数组元素超出预定义字符串长度时收到错误提示 
scott@CNMMBO> insert into tb_emp select 8888,'Johnson',varray_phone('13423456789000000000000000000000000000000000000')   
  2  from dual; 
insert into tb_emp select 8888,'Johnson',varray_phone('13423456789000000000000000000000000000000000000')  
 * 
ERROR at line 1: 
ORA-22814: attribute or element value is larger than specified in type 
 
-->修改变长数组元素的数据长度到varchar2(60),且使用cascade,即及联修改到表tb_emp 
scott@CNMMBO> alter type varray_phone modify element type varchar2(60) cascade; 
Type altered. 
-->再次插入数据成功 
scott@CNMMBO> insert into tb_emp select 8888,'Johnson',varray_phone('13423456789000000000000000000000000000000000000') 2  from dual; 
 1 row created. 
 
-->查看变长数组的定义 
scott@CNMMBO> select parent_table_name,parent_table_column,type_name from user_varrays; 
PARENT_TABLE_NA PARENT_TABLE_COLUMN   TYPE_NAME 
--------------- ------------------------------ ------------------------------ 
TB_EMP PHONE VARRAY_PHONE

PL/SQL — 变长数组的更多相关文章

  1. PL/SQL 嵌套表变长数组和索引表[转]

    关于PL/SQL中这三种数组的介绍,不想写了.转一篇日志吧…… 链接:http://www.blogjava.net/decode360/archive/2008/08/08/280825.html ...

  2. oracle:变长数组varray,嵌套表,集合

    创建变长数组类型 ) );  这个变长数组最多可以容纳两个数据,数据的类型为 varchar2(50) 更改元素类型的大小或精度 可以更改变长数组类型和嵌套表类型 元素的大小. ALTER TYPE ...

  3. GCC 中零长数组与变长数组

    前两天看程序,发现在某个函数中有下面这段程序: int n; //define a variable n int array[n]; //define an array with length n 在 ...

  4. C++内存分配及变长数组的动态分配

    //------------------------------------------------------------------------------------------------ 第 ...

  5. C99新特性:变长数组(VLA)

    C99标准引入了变长数组,它允许使用变量定义数组各维.例如您可以使用下面的声明: ; ; double sales[rows][cols]; // 一个变长数组(VLA) 变长数组有一些限制,它必须是 ...

  6. c语言,变长数组

    下面这个结构体,可以在malloc的时候指定数据data的长度,这样的形式就是变长数组:typedef struct{ int data_len; char data[0];//或char data[ ...

  7. C99中的变长数组(VLA)

    处理二维数组的函数有一处可能不太容易理解,数组的行可以在函数调用的时候传递,但是数组的列却只能被预置在函数内部.例如下面这样的定义: #define COLS 4 int sum3d(int ar[] ...

  8. C语言变长数组 struct中char data[0]的用法

    版权声明:本文为博主原创文章,未经博主允许不得转载. 今天在看一段代码时出现了用结构体实现变长数组的写法,一开始因为忘记了这种技术,所以老觉得作者的源码有误,最后经过我深思之后,终于想起以前看过的用s ...

  9. C语言变长数组data[0]总结

    C语言变长数组data[0] 1.前言 今天在看代码中遇到一个结构中包含char data[0],第一次见到时感觉很奇怪,数组的长度怎么可以为零呢?于是上网搜索一下这样的用法的目的,发现在linux内 ...

随机推荐

  1. Routing and controllers

    Routing and controllers We will build a very simple inventory system to display our album collection ...

  2. 对于jdk jre jvm的简单认识

    1:名词解释 jdk:java  develop  kit:java开发工具包 jre:java runtime  environment :java开发运行时环境 jvm:java virtua m ...

  3. readint writeint

    inline int readint() { char c = getchar(); while(!isdigit(c)) c = getchar(); ; while(isdigit(c)) { x ...

  4. strstr,strchr,strtr 比较

    strstr - 查找字符串的首次出现 查找 "Shanghai" 在字符串中的第一次出现,并返回字符串的剩余部分: echo strstr("I love Shangh ...

  5. 配置Linux数据转发(给其他接口转发一个接口的internet网络)

    配置Linux数据转发 [主机]第一步开启转发net.ipv4.ip_forward = 1echo "1" > /proc/sys/net/ipv4/ip_forward第 ...

  6. 【Objective-C】0-第一个OC的类

    OC是一门面向对象的语言,因此它也有类.对象.静态\动态方法.成员变量的概念.这讲就来创建第一个OC的类. 一.语法简介 1.类 在Java中,我们用1个.java文件就可以描述清楚一个类:在OC中, ...

  7. Spring 3.x 实践 第一个例子(Spring 3.x 企业应用开发实战读书笔记第二章)

    前言:工作之后一直在搞android,现在需要更多和后台的人员交涉,技术栈不一样,难免鸡同鸭讲,所以稍稍学习下. 这个例子取自于<Spring 3.x 企业应用开发实战>一书中的第二章,I ...

  8. content = "IE=edge,chrome=1" 详解

    content = "IE=edge,chrome=1" 详解 < meta http-equiv = "X-UA-Compatible" content ...

  9. WEB系统技术开发方向

    1. UI框架:要可以结合jquery+自定义服务器控件开发一套UI框架: 2.WEB报表设计器:用js开发一套可以自定义报表设计器: 3.WEB自定义表单+工作流设计器: 4.WEB打印组件: 5. ...

  10. article元素设计网络新闻展示

    article元素用来表示文档.页面中独立的.完整的.可以独自被外部引用的内容.它可以是一篇文章博客或者报刊中的文章.一篇论坛帖子.一段用户评论或独立的插件等.除了内容部分,一个article元素通常 ...