【问题标题】:postgresql serial pk reverts to integer after restorepostgresql 串行 pk 恢复后恢复为整数
【发布时间】:2019-10-12 09:47:16
【问题描述】:

我为 pks 构建了一个串行类型的数据库,我迁移到另一台服务器,pk 列现在是整数,因此由于 pk 的非空限制,我无法添加新数据。有什么 Alter 命令可以解决这个问题吗?

【问题讨论】:

  • 如果通过pg_dump+pg_restore“迁移”,就不会出现这个“问题”。

标签: postgresql primary-key restore autonumber


【解决方案1】:

SERIAL 不是 postgresql 中的数据类型,只是创建表时的一个方便词,它使列成为整数类型并添加自动递增。您所要做的就是将自动递增(序列)添加回列,并确保其下一个值大于表中的任何值。

This question covers adding serial to an existing column

This answer explains how to reset the counter

【讨论】:

  • 我选择的解决方案:SELECT MAX(ticket_id) + 1 FROM Tickets_ticket;创建序列 ticket_ticket_a_seq 以 25 开头; ALTER TABLE ticket_ticket ALTER COLUMN ticket_id SET DEFAULT nextval('tickets_ticket_a_seq');
猜你喜欢
  • 2014-08-09
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-01-19
  • 1970-01-01
  • 1970-01-01
  • 2021-04-17
  • 2017-02-14
相关资源
最近更新 更多