我有一个定义如下的 postgres 表:
CREATE TABLE public.Table_1
(
id bigint NOT NULL GENERATED ALWAYS AS IDENTITY ( INCREMENT 1
START 1 MINVALUE 1 MAXVALUE 9223372036854775807 CACHE 1 )
)
由于数据迁移,id 列被弄乱了,在 INSERT 上生成的 id 值不是唯一的。因此,我需要如下重置 id 列
SELECT MAX(id) + 1 From Table_1;
ALTER TABLE Table_1 ALTER COLUMN id RESTART WITH 935074;
现在我运行第一个查询来获取 Max(id) + 1 值,然后我需要在 ALTER 查询中替换它。 有没有一种方法可以存储 SELECT 的结果并只使用 ALTER 语句中的变量?
最佳答案
这是一种方法:
select setval(pg_get_serial_sequence('Table_1', 'id'), coalesce(max(id),0) + 1, false)
from Table_1;
理由:
pg_get_serial_sequence()
返回给定表和列的序列名称set_val()
可用于重置序列- 这可以包含在
select
中,为您提供表中id
的当前最大值(如果表为空,则为 1)
关于sql - 在 postgres 中使用 select inside alter table 语句的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59811082/