Qual é o problema de negócios que você está tentando resolver? É excepcionalmente raro que você precise usar tabelas temporárias no Oracle. Por que você simplesmente não
SELECT *
FROM employees
WHERE id = p_id_passed_in;
Em outros bancos de dados, você geralmente cria tabelas temporárias porque os leitores bloqueiam os gravadores, portanto, você deseja criar uma cópia separada dos dados para evitar o bloqueio de outras sessões. No Oracle, no entanto, os leitores nunca bloqueiam os escritores, portanto, geralmente não há necessidade de salvar uma cópia separada dos dados.
Em outros bancos de dados, você cria tabelas temporárias porque não deseja fazer leituras sujas. O Oracle, no entanto, não permite leituras sujas. A consistência de leitura de várias versões significa que o Oracle sempre mostrará os dados como existiam quando a consulta foi iniciada (ou quando a transação foi iniciada, se você definiu um nível de isolamento de transação como serializável). Portanto, não há necessidade de criar uma tabela temporária para evitar leituras sujas.
Se você realmente quisesse usar tabelas temporárias no Oracle, você não criaria a tabela dinamicamente. Você criaria uma tabela temporária global antes de criar o procedimento armazenado. A estrutura da tabela seria visível para todas as sessões, mas os dados seriam visíveis apenas para a sessão que a inseriu. Você preencheria a tabela temporária no procedimento e, em seguida, consultaria a tabela. Algo como
CREATE GLOBAL TEMPORARY TABLE temp_emp (
empno number,
ename varchar2(10),
job varchar2(9),
mgr number,
sal number(7,2)
)
ON COMMIT PRESERVE ROWS;
CREATE OR REPLACE PROCEDURE populate_temp_emp
AS
BEGIN
INSERT INTO temp_emp( empno,
ename,
job,
mgr,
sal )
SELECT empno,
ename,
job,
mgr,
sal
FROM emp;
END;
/
SQL> begin
2 populate_temp_emp;
3 end;
4 /
PL/SQL procedure successfully completed.
SQL> select *
2 from temp_emp;
EMPNO ENAME JOB MGR SAL
---------- ---------- --------- ---------- ----------
7623 PAV Dev
7369 smith CLERK 7902 800
7499 ALLEN SALESMAN 7698 1600
7521 WARD SALESMAN 7698 1250
7566 JONES MANAGER 7839 2975
7654 MARTIN SALESMAN 7698 1250
7698 BLAKE MANAGER 7839 2850
7782 CLARK MANAGER 7839 2450
7788 SCOTT ANALYST 7566 3000
7839 KING PRESIDENT 5000
7844 TURNER SALESMAN 7698 1500
7876 ADAMS CLERK 7788 1110
7900 SM0 CLERK 7698 950
7902 FORD ANALYST 7566 3000
7934 MILLER CLERK 7782 1300
1234 BAR
16 rows selected.
Como eu disse, no entanto, seria muito incomum no Oracle realmente querer usar uma tabela temporária.