oracle – IN子句的函数或过程
发布时间:2020-12-12 16:25:30 所属栏目:百科 来源:网络整理
导读:我想编写一个可以在另一个过程的IN子句中使用的函数或过程.该函数或过程将返回ID号. 主程序会说类似的东西 SELECT *FROM EMPLOYEESWHERE OFFICE_ID IN (GET_OFFICE_IDS); -- GET_OFFICE_IDS requires no parameters GET_OFFICE_IDS返回一个VARCHAR2,ID以逗号
我想编写一个可以在另一个过程的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来创建主程序使用的临时表?如果是这样,是否会有性能损失? 以下是使用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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |