postgresql – 压缩或重新编号所有表的ID,并将序列重置为max(id)?

运行了很长时间后,我在id字段中得到越来越多的漏洞.一些表的id是int32,id序列达到了它的最大值.一些 Java代码是只读的,所以我不能简单地将id列类型从int32更改为long,这会破坏API.

我想重新编号.这可能不是一个好的做法,但好或坏并不关心这个问题.我想重新编号,尤其是那些很长的ID,如“61789238”,“548273826529524324”.我不知道他们为什么这么久,但更短的ID也更容易手动处理.

但由于引用和约束,手动压缩ID并不容易.

Postgresql本身是否支持ID重新编号?或者这项工作是否有任何插件或维护工具?

也许我可以写一些存储过程?那将是非常好的,所以我可以每年安排一次.

假设您的id是从bignum序列生成的,只需重新启动序列并使用idcolumn = DEFAULT更新表.

CAVEAT:如果此id列被其他表用作外键,请确保已打开on update cascade修饰符.

例如:

创建表,放入一些数据,并删除中间值:

db=# create sequence xseq;
CREATE SEQUENCE
db=# create table foo ( id bigint default nextval('xseq') not null,data text );
CREATE TABLE
db=# insert into foo (data) values ('hello'),('world'),('how'),('are'),('you');
INSERT 0 5
db=# delete from foo where data = 'how';
DELETE 1
db=# select * from foo;
 id | data  
----+-------
  1 | hello
  2 | world
  4 | are
  5 | you
(4 rows)

重置您的序列:

db=# ALTER SEQUENCE xseq RESTART;
ALTER SEQUENCE

更新您的数据:

db=# update foo set id = DEFAULT;
UPDATE 4
db=# select * from foo;
 id | data  
----+-------
  1 | hello
  2 | world
  3 | are
  4 | you
(4 rows)

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...