sequence向后推移

昨天导入一个数据库,用户反映导过来的有sequence要小于已经导入到表中的sequence的值。原因生产数据中seq导入的时候可能在操作,
导致出现一些重复的出现。为了解决这个问题,我把当前用户下所有的sequence全部向后延至200,具体操作如下:

create table MAHANSO_TEST
(
  ID       NUMBER,
  SEQUENCE VARCHAR2(100)
)


DECLARE
   CURSOR c_cursor IS 
   select sequence_name from user_sequences;
   v_sequences_name user_sequences.sequence_name%type;
   
   v_sql varchar2(2000);
   v_insert_sql varchar2(2000);
   v_sequences_value number;
BEGIN
--隐含打开游标
   FOR v_sequences_name IN c_cursor LOOP
   --隐含执行一个FETCH语句
      for int in 1..1000 loop 
      v_sql := 'select '||v_sequences_name.sequence_name||'.Nextval from dual';
      --v_sql := v_sequences_name;
      --dbms_output.put_line(v_sql);
      execute immediate v_sql into v_sequences_value;
      
      v_insert_sql := 'insert into mahanso_test values(:1,:2)';
      execute immediate v_insert_sql using v_sequences_value,v_sequences_name.sequence_name;
      commit;
      end loop;
   --隐含监测c_sal%NOTFOUND
     END LOOP;
--隐含关闭游标
END;
备注:此脚本是网上找来修改的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值