Apa masalah bisnis yang Anda coba selesaikan? Sangat jarang Anda perlu menggunakan tabel sementara di Oracle. Mengapa Anda tidak
SELECT *
FROM employees
WHERE id = p_id_passed_in;
Di database lain, Anda sering membuat tabel sementara karena pembaca memblokir penulis sehingga Anda ingin membuat salinan data terpisah untuk menghindari pemblokiran sesi lainnya. Namun, di Oracle, pembaca tidak pernah memblokir penulis, jadi umumnya tidak perlu menyimpan salinan data yang terpisah.
Di database lain, Anda membuat tabel sementara karena Anda tidak ingin melakukan pembacaan kotor. Oracle, bagaimanapun, tidak mengizinkan pembacaan kotor. Konsistensi membaca multi-versi berarti bahwa Oracle akan selalu menampilkan data sebagaimana adanya saat kueri dimulai (atau saat transaksi dimulai jika Anda telah menetapkan tingkat isolasi transaksi yang dapat diserialisasi). Jadi tidak perlu membuat tabel sementara untuk menghindari pembacaan yang kotor.
Jika Anda benar ingin menggunakan tabel sementara di Oracle, Anda tidak akan membuat tabel secara dinamis. Anda akan membuat tabel sementara global sebelum Anda membuat prosedur tersimpan. Struktur tabel akan terlihat oleh semua sesi tetapi data hanya akan terlihat oleh sesi yang menyisipkannya. Anda akan mengisi tabel sementara dalam prosedur dan kemudian kueri tabel. Sesuatu seperti
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.
Seperti yang saya katakan, akan sangat tidak biasa di Oracle untuk benar-benar ingin menggunakan tabel sementara.