PostgreSQL数据库中初始化所有序列的当前值

Postgresql中当我们创建Sequence序列的时候,往往初始值是1并以此开始做递增作为相应的数据表列中插入的默认值,当相应表的初始数据来源于外部(比如原来项目采用的是MSSQL时)迁移而来的数据时,这时序列的当前值与数据中的相应列的最大值并不同步,这时需要重新设置数库表中各个表的序列的当前值,以便下次插入数据时不会插入重复的序列值。

以下脚本可以自动同步DB中所有Serial类型产生的序列的当前值为相应表的最大ID值,并让下次插入时得到递增的值:

--初始化所有序列的当前值:
do $body$
declare 
    seq_name text;
    table_and_id_string text;
    table_name text;
    id_name text;
    sqltext text:='';
    delimiter_reverse_pos integer;
begin
     for seq_name in select relname from pg_class where relkind='S' order by relname loop
         if seq_name like '%_seq' then
            table_and_id_string:=substr(seq_name,1,length(seq_name)-4);
            delimiter_reverse_pos:=strpos(reverse(table_and_id_string),'_');
            table_name:=left(table_and_id_string,length(table_and_id_string)-delimiter_reverse_pos);
            id_name:=right(table_and_id_string,delimiter_reverse_pos-1);
            sqltext:=sqltext||'select setval(''"'||seq_name|| '"'',(select max("'||id_name||'") from "'||table_name||'"));'||chr(10);
        end if;         
     end loop;
     --raise notice '%',sqltext;
     execute sqltext;
     EXCEPTION
        WHEN others THEN
            RAISE NOTICE '%', '执行出错,请检查是否从序列名中匹配的对象不存在!';
            RAISE EXCEPTION '(%)', SQLERRM; 
end
$body$;

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值