我试图将一个序列设置为一个特定的值。

SELECT setval('payments_id_seq'), 21, true;

这将给出一个错误:

错误:函数setval不存在

使用ALTER SEQUENCE似乎也不工作?

ALTER SEQUENCE payments_id_seq LASTVALUE 22;

如何做到这一点呢?

裁判:https://www.postgresql.org/docs/current/functions-sequence.html

我遇到了一个问题,我的主键序列与我的表行不同步。

也就是说,当我插入一个新行时,我得到一个重复的键错误,因为在串行数据类型中隐含的序列返回一个已经存在的数字。

这似乎是由于导入/恢复没有正确地维护序列造成的。