当前位置:  开发笔记 > 编程语言 > 正文

IN子句的函数或过程

如何解决《IN子句的函数或过程》经验,为你挑选了1个好方法。

我想编写一个可以在另一个过程的IN子句中使用的函数或过程.该函数或过程将返回ID号.

主程序会说类似的东西

SELECT *
FROM EMPLOYEES
WHERE OFFICE_ID IN (GET_OFFICE_IDS);  -- GET_OFFICE_IDS requires no parameters

GET_OFFICE_IDS返回一个VARCHAR2,ID以逗号分隔.当我运行主程序时,我得到一个"ORA-01722:无效数字"错误,这是有道理的,但我不知道我需要从这里去哪里.

我是否需要GET_OFFICE_IDS来创建主程序使用的临时表?如果是这样,是否会有性能损失?



1> Tony Andrews..:

以下是使用EMP表的嵌套表解决方案的工作示例:

create type t_ids is table of integer
/

create or replace function get_office_ids return t_ids
is
   l_ids t_ids := t_ids();
   l_idx integer := 0;
begin
   for r in (select empno from emp where deptno=10)
   loop
      l_ids.extend;
      l_idx := l_idx+1;
      l_ids(l_idx) := r.empno;
   end loop;
   return l_ids;
end;
/

select ename from emp where empno in (select * from table(get_office_ids));


ENAME
----------
CLARK
KING
TEST
MILLER
BINNSY
FARMER

推荐阅读
echo7111436
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有