CREATE OR REPLACE PROCEDURE proc_name AS
BEGIN
EXECUTE IMMEDIATE 'DROP TABLE SQL2005TEST.ABSENCEFULLDATADIFF_YESTERDAY';
.....
EXECUTE IMMEDIATE 'CREATE TABLE SQL2005TEST.ABSENCELATESTEND_YESTERDAY
AS SELECT * FROM SQL2005TEST.ABSENCELATESTEND';
....
....
EXCEPTION
....
....
END;
EXECUTE IMMEDIATE
příkaz spustí dynamický příkaz SQL nebo anonymní blok PL/SQL v rámci bloku PL/SQL nebo uložené procedury nebo balíčku. Toto se konkrétněji používá, pokud potřebujete spouštět příkazy DDL jako DROP
, CREATE TABLE
atd. Příkazy DDL z PL/SQL nemůžete spouštět jako příkazy DML, takže jedinou cestou je dynamické SQL. Další informace zde
a zde
.