pgsql 重置所有按规则命名的序列

pgsql 重置所有按规则命名的序列

因为在项目中使用hibernate使用注解进行映射,使用序列获取id值,但是数据库迁移后序列并没有迁移,导致程序启动后,自动创建序列进行查询时,对于有多条记录的表,序列仍从1开始,向表中插入数据,仍会出现很多错误,因此参考了其它文章代码改动,进行序列重设

需要根据情况更改逻辑

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
           -- 根据实际的规则,条件判断是否是要处理的序列(这里是找到以s_开头的序列进行处理)
			if seq_name like 's_%' then
			    table_name:=substr(seq_name,3,length(seq_name));
			       -- 设置序列的currentValue
					sqltext:=sqltext||'select setval(''schema.'||seq_name|| ''',(select max("id") from schema.'||table_name||'));'||chr(10);
			   		 -- 重置表的序列
			   		sqltext:=sqltext||'alter table schema.'||table_name||' alter column id set default nextval(''yth_dap.'||seq_name||''');'||chr(10);	
			end if;
     end loop;
		 RAISE NOTICE '%',sqltext;  -- 也通过此语句打印出拼接的sql语句
         --      execute sqltext;  --  可以在此执行语句
     EXCEPTION
        WHEN others THEN
            RAISE NOTICE '%', '执行出错,请检查是否从序列名中匹配的对象不存在!';
            RAISE EXCEPTION '(%)', SQLERRM; 
end
$body$;
···
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值