微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从Oracle表变量/数组中选择值?

接下来我的最后一个问题( Table Variables in Oracle PL/SQL?)…

一旦你在数组/表中有值,你又怎么把它们重新出来呢?最好使用select语句或类似的东西?

这是我到目前为止

declare
    type array is table of number index by binary_integer;
    pidms array;
begin
    for i in    (
                select distinct sgbstdn_pidm
                from sgbstdn
                where sgbstdn_majr_code_1 = 'HS04'
                and sgbstdn_program_1 = 'HSCOMPH'
                )
    loop
        pidms(pidms.count+1) := i.sgbstdn_pidm;
    end loop;

    select *
    from pidms; --ORACLE DOESN'T LIKE THIS BIT!!!
end;

我知道我可以使用dbms_output.putline()输出它们,但我希望从任何其他表中选择一个结果集.

提前致谢,
马特

您可能需要一个GLOBAL TEMPORARY TABLE.

在Oracle中,这些被创建一次,然后被调用时,数据对你的会话是私有的.

Oracle Documentation Link

尝试这样的东西…

CREATE GLOBAL TEMPORARY TABLE temp_number
   ( number_column   NUMBER( 10,0 )
   )
   ON COMMIT DELETE ROWS;

BEGIN 
   INSERT INTO temp_number
      ( number_column )
      ( select distinct sgbstdn_pidm 
          from sgbstdn 
         where sgbstdn_majr_code_1 = 'HS04' 
           and sgbstdn_program_1 = 'HSCOMPH' 
      ); 

    FOR pidms_rec IN ( SELECT number_column FROM temp_number )
    LOOP 
        -- Do something here
        NULL; 
    END LOOP; 
END; 
/

原文地址:https://www.jb51.cc/oracle/204952.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐