Сбой выполнения этого триггера (он компилируется, но как только я выполняю указанную вставку -> ошибка)
create or replace
TRIGGER AFT_INSERT_TMP_TBL
AFTER INSERT ON TMP_TBL
REFERENCING OLD AS OLD NEW AS NEW
FOR EACH ROW
DECLARE
V_SQL VARCHAR2(1000);
A_NAME VARCHAR2(100);
BEGIN
A_NAME:='ANY_NAME';
V_SQL:='BEGIN
DBMS_SCHEDULER.CREATE_JOB (
job_name => '''||A_NAME||''',
job_type => ''PLSQL_BLOCK'',
job_action => ''BEGIN DBMS_OUTPUT.PUT_LINE('||A_NAME||'); END;'',
start_date => TIMESTAMP''2011-12-4 10:30:00'',
repeat_interval => ''FREQ=MINUTELY;INTERVAL=2'',
auto_drop => FALSE,
comments => '''||A_NAME||''');
END;';
DBMS_OUTPUT.PUT_LINE('SCHEDULER :'||V_SQL);
EXECUTE IMMEDIATE V_SQL;
END AFT_INSERT_TMP_TBL;
-----------------------
Напечатанный код создания SCHEDULER полностью действителен.
Я получаюORA-04092 'не может в триггере ... Триггер попытался зафиксировать или откатить.Перепишите триггер, чтобы он не фиксировался и не откатывался ».
Это «коммит»?Таким образом, JOB не может быть создан внутри триггера?
Я знаю, что использовал триггеры со вставками в разные таблицы, и это тоже "коммит", и Oracle не жаловался.