zoukankan      html  css  js  c++  java
  • oracle数组使用实例

    <一维数组
    SET SERVEROUT ON SIZE 100000
    DECLARE
      TYPE T_VARRAY IS VARRAY(3) OF VARCHAR2(20);
      V_VAR T_VARRAY := T_VARRAY('I', 'LOVE', 'STUDY');
    BEGIN
      FOR I IN 1 .. V_VAR.COUNT LOOP
        DBMS_OUTPUT.PUT_LINE(V_VAR(I));
      END LOOP;
    END;
    /

    <二维数组
    <二维数组EXAMPLE1
    DECLARE
      TYPE T_VARRAY IS VARRAY(5) OF NUMBER;
      TYPE T_VARRAY_VARRAY IS VARRAY(2) OF T_VARRAY;
      V_VAR T_VARRAY_VARRAY := T_VARRAY_VARRAY(T_VARRAY(11, 12, 13, 14, 15),
                                               T_VARRAY(21, 22, 23, 24, 25));
    BEGIN
      FOR I IN 1 .. V_VAR.COUNT LOOP
        FOR J IN 1 .. V_VAR(I).COUNT LOOP
          DBMS_OUTPUT.PUT_LINE(V_VAR(I) (J));
        END LOOP;
      END LOOP;
    END;
    /
    <二维数组EXAMPLE2
    DECLARE
      TYPE T_NUM IS TABLE OF NUMBER INDEX BY BINARY_INTEGER;
      TYPE T_VAR IS TABLE OF NUMBER INDEX BY VARCHAR2(10);
      TYPE T_NUM_VAR IS TABLE OF T_NUM INDEX BY VARCHAR2(10);
      TYPE T_VAR_NUM IS TABLE OF T_VAR INDEX BY BINARY_INTEGER;
      V_NUM_VAR T_NUM_VAR;
      V_VAR_NUM T_VAR_NUM;
    BEGIN
      V_NUM_VAR('A')(5) := 1;
      V_VAR_NUM(5)('A') := 1;
    END;
    /

    <可变数组
    --嵌套表
    TYPE tbl_t IS TABLE OF VARCHAR2(30);
    my_tbl tbl_t := tbl_t('a', 'b', 'c'); --初始化
    Oracle除了数组类型VARRAY之外,还有嵌套表和索引表也都可以实现类似数组的功能。
    使用索引表定义数组,不需要指定数组的上限,数组的大小只与内存限制有关。
    <可变数组EXAMPLE1
    DECLARE
      TYPE T_TAB IS TABLE OF NUMBER INDEX BY VARCHAR2(30);
      --索引是数组的下标
      V_VAR T_TAB;
      V_STR VARCHAR2(30);
    BEGIN
      FOR I IN (SELECT OWNER, COUNT(1) CN FROM DBA_TABLES GROUP BY OWNER) LOOP
        V_VAR(I.OWNER) := I.CN;
        --索引是数组的下标
      END LOOP;
      V_STR := V_VAR.FIRST;
      WHILE (V_VAR.EXISTS(V_STR)) LOOP
        DBMS_OUTPUT.PUT_LINE(RPAD(V_STR, 20, '-') || ':' || V_VAR(V_STR));
        V_STR := V_VAR.NEXT(V_STR);
      END LOOP;
    END;
    /
    CTXSYS--------------:36
    DEV-----------------:1915
    HR------------------:7
    MARS3_WEB_USR-------:9
    <可变数组EXAMPLE2
    DECLARE
      TYPE T_REC IS RECORD(
        VINT INTEGER,
        VCHR VARCHAR2(100));
      TYPE T_TAB IS TABLE OF T_REC INDEX BY BINARY_INTEGER;
      --T_REC 等价 EMP%ROWTYPE
      V_VAR T_TAB;
      Y     INTEGER := 1;
    BEGIN
      FOR X IN 1 .. 3 LOOP
        V_VAR(X).VINT := X;
        V_VAR(X).VCHR := TO_CHAR(V_VAR(X).VINT, '$09.00');
      END LOOP;
      WHILE (V_VAR.EXISTS(Y)) LOOP
        DBMS_OUTPUT.PUT_LINE(V_VAR(Y).VINT || '/' || V_VAR(Y).VCHR);
        Y := Y + 1;
      END LOOP;
    END;
    /
    1/ $01.00
    2/ $02.00
    3/ $03.00

    <可变数组EXAMPLE3
    DECLARE
      TYPE T_TAB IS TABLE OF VARCHAR2(20) INDEX BY BINARY_INTEGER;
      V_VAR T_TAB;
    BEGIN
      V_VAR(1) := '北京';
      V_VAR(2) := '上海';
      V_VAR(3) := '广州';
      DBMS_OUTPUT.PUT_LINE('共有记录:' || V_VAR.COUNT);
      DBMS_OUTPUT.PUT_LINE('第一条:' || V_VAR.FIRST);
      DBMS_OUTPUT.PUT_LINE('最后一条:' || V_VAR.LAST);
      DBMS_OUTPUT.PUT_LINE('第二条的前一条:' || V_VAR.PRIOR(2));
      DBMS_OUTPUT.PUT_LINE('第二条的后一条:' || V_VAR.NEXT(2));
      --COUNT,FIRST,LAST,NEXT,PRIOR方法返回的值是整数
      --以下3种表示的内容相同:
      DBMS_OUTPUT.PUT_LINE('第一条记录内容:' || V_VAR(V_VAR.PRIOR(2)));
      DBMS_OUTPUT.PUT_LINE('第一条记录内容:' || V_VAR(V_VAR.FIRST));
      DBMS_OUTPUT.PUT_LINE('第一条记录内容:' || V_VAR(1));
    END;
    /
    共有记录:3
    第一条:1
    最后一条:3
    第二条的前一条:1
    第二条的后一条:3
    第一条记录内容:北京
    第一条记录内容:北京
    第一条记录内容:北京

    <可变数组EXAMPLE4
    DECLARE
      TYPE T_TAB IS TABLE OF VARCHAR2(20);
      V_VAR T_TAB := T_TAB('北京', '上海', '广州');
      --ORA-06531: Reference to uninitialized collection
      --如果没有 INDEX BY BINARY_INTEGER ,则需 初始化
    BEGIN
      V_VAR(1) := '$北京';
      V_VAR(2) := '$上海';
      V_VAR(3) := '$广州';
      DBMS_OUTPUT.PUT_LINE('共有记录:' || V_VAR.COUNT);
      DBMS_OUTPUT.PUT_LINE('第一条:' || V_VAR.FIRST);
      DBMS_OUTPUT.PUT_LINE('最后一条:' || V_VAR.LAST);
      DBMS_OUTPUT.PUT_LINE('第二条的前一条:' || V_VAR.PRIOR(2));
      DBMS_OUTPUT.PUT_LINE('第二条的后一条:' || V_VAR.NEXT(2));
      --COUNT,FIRST,LAST,NEXT,PRIOR方法返回的值是整数
      --以下3种表示的内容相同:
      DBMS_OUTPUT.PUT_LINE('第一条记录内容:' || V_VAR(V_VAR.PRIOR(2)));
      DBMS_OUTPUT.PUT_LINE('第一条记录内容:' || V_VAR(V_VAR.FIRST));
      DBMS_OUTPUT.PUT_LINE('第一条记录内容:' || V_VAR(1));
    END;
    /
    共有记录:3
    第一条:1
    最后一条:3
    第二条的前一条:1
    第二条的后一条:3
    第一条记录内容:$北京
    第一条记录内容:$北京
    第一条记录内容:$北京

  • 相关阅读:
    rabbitmq集群几个比较好的文章
    rabbitmq集群步骤
    rabbitmq安装
    查找出系统中大于50k 且小于100k 的文件并删除。
    现将文件a.txt 中的所有abc 替换成def
    统计/var/log/下有多少文件
    压缩解压目录结构不能改变
    chkconfig命令
    linux运维必须掌握
    三剑客
  • 原文地址:https://www.cnblogs.com/songzhenhua/p/9312853.html
Copyright © 2011-2022 走看看