Создайте последовательность с помощью START WITH из Query
Как создать последовательность, в которой значение START WITH получено из запроса?
Я пытаюсь так:
CREATE SEQUENCE "Seq" INCREMENT BY 1 START WITH (SELECT MAX("ID") FROM "Table");
Но я получаю ошибку ORA-01722
Ответ 1
START WITH CLAUSE принимает целое число. Вы можете динамически сформировать оператор "Создать последовательность", а затем выполнить его с помощью команды "Выполнить немедленно".
declare
l_new_seq INTEGER;
begin
select max(id) + 1
into l_new_seq
from test_table;
execute immediate 'Create sequence test_seq_2
start with ' || l_new_seq ||
' increment by 1';
end;
/
declare
ex number;
begin
select MAX(MAX_FK_ID) + 1 into ex from TABLE;
If ex > 0 then
begin
execute immediate 'DROP SEQUENCE SQ_NAME';
exception when others then
null;
end;
execute immediate 'CREATE SEQUENCE SQ_NAME INCREMENT BY 1 START WITH ' || ex || ' NOCYCLE CACHE 20 NOORDER';
end if;
end;