Create a Sequence with START WITH from Query Create a Sequence with START WITH from Query oracle oracle

Create a Sequence with START WITH from Query


The START WITH CLAUSE accepts an integer. You can form the "Create sequence " statement dynamically and then execute it using execute immediate to achieve this.

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;/

Check out these links.

http://download.oracle.com/docs/cd/B14117_01/server.101/b10759/statements_6014.htm
http://download.oracle.com/docs/cd/B19306_01/appdev.102/b14261/executeimmediate_statement.htm


Here I have my example which works just fine:

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;