Chà, nó có thể không dài dòng hơn nhiều, nhưng PL / SQL này là một tùy chọn:
begin
for r in (select *
from table_name
where pk_id = 'original_primary_key')
loop
r.pk := pk_seq.nextval;
r.fk := 'foreign-key';
insert into table_name values r;
end loop;
end;