Hvad er det forretningsproblem, du forsøger at løse? Det er usædvanligt sjældent, at du skal bruge midlertidige tabeller i Oracle. Hvorfor ville du ikke bare
SELECT *
FROM employees
WHERE id = p_id_passed_in;
I andre databaser opretter du ofte midlertidige tabeller, fordi læsere blokerer forfattere, så du vil oprette en separat kopi af dataene for at undgå at blokere andre sessioner. I Oracle blokerer læsere dog aldrig forfattere, så der er generelt ingen grund til at gemme en separat kopi af dataene.
I andre databaser opretter du midlertidige tabeller, fordi du ikke ønsker at lave beskidte læsninger. Oracle tillader dog ikke beskidte læsninger. Læsekonsistens i flere versioner betyder, at Oracle altid vil vise dig dataene, som de eksisterede, da forespørgslen blev startet (eller da transaktionen startede, hvis du har angivet et transaktionsisoleringsniveau for serialiserbar). Så der er ingen grund til at oprette en midlertidig tabel for at undgå beskidte læsninger.
Hvis du virkelig ønskede at bruge midlertidige tabeller i Oracle, ville du ikke oprette tabellen dynamisk. Du ville oprette en global midlertidig tabel, før du oprettede den lagrede procedure. Tabelstrukturen ville være synlig for alle sessioner, men dataene ville kun være synlige for den session, der indsatte dem. Du vil udfylde den midlertidige tabel i proceduren og derefter forespørge tabellen. Noget lignende
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.
Som jeg sagde, ville det dog være meget usædvanligt i Oracle rent faktisk at ville bruge en midlertidig tabel.