Oracle Text Printing Sync на один индекс
-
28-09-2019 - |
Вопрос
Мне нужно синхронизировать текстовый индекс Oracle. Но работа не может создавать:
declare
v_job_id number(19,0);
begin
dbms_job.submit(
JOB => v_job_id,
WHAT => 'alter index NAME_IDX rebuild parameters (''sync'');',
NEXT_DATE => SYSDATE + (1/24),
INTERVAL => 'SYSDATE + (1/24) + 7'
);
end;
/
Или запустить:
declare
v_job_id number(19,0);
begin
dbms_job.submit(
JOB => v_job_id,
WHAT => 'CTX_DDL(''NAME_IDX'');',
NEXT_DATE => SYSDATE + (1/24),
INTERVAL => 'SYSDATE + (1/24) + 7'
);
end;
/
Но если я бегу любую из этих работ:
alter index NAME_IDX rebuild parameters ('sync');
call CTX_DDL('NAME_IDX');
Любая идея правильного синтаксиса?
Спасибо.
PD: Ive искал, но единственный ответ, который я нашел, не соответствует моим требованиям. Я также извиняюсь за мой английский.
Решение
Вы можете запустить анонимный блок, звонок не находится в PL / SQL, ALTER INDEX - это DDL, и вам нужно указать, какую процедуру в CTX_DDL вы хотите запустить:
WHAT => 'BEGIN EXECUTE IMMEDIATE ''alter index NAME_IDX rebuild parameters (''''sync'''')''; CTX_DDL.sync_index(''NAME_IDX''); END',
Однако лично я предпочитаю инкапсулировать его в процедуре (или, даже лучше, пакет) и позвонить в процедуру с работы:
CREATE PROCEDURE rebuild_name_idx IS
BEGIN
EXECUTE IMMEDIATE 'alter index NAME_IDX rebuild parameters (''sync'')';
CTX_DDL.sync_index('NAME_IDX');
END;
/
declare
v_job_id number(19,0);
begin
dbms_job.submit(
JOB => v_job_id,
WHAT => 'rebuild_name_idx;',
NEXT_DATE => SYSDATE + (1/24),
INTERVAL => 'SYSDATE + (1/24) + 7'
);
end;
/
Кроме того, я уверен, что вам на самом деле не нужно восстановить индекс - вам нужно только позвонить CTX_DDL.sync_index
Чтобы обновить его от любого DML на столе.