我遇到了我的主键序列与我的表行不同步的问题。
也就是说,当我插入一个新行时,我得到一个重复键错误,因为串行数据类型中隐含的序列返回一个已经存在的数字。
这似乎是由于导入/恢复没有正确维护顺序引起的。
原文由 meleyal 发布,翻译遵循 CC BY-SA 4.0 许可协议
我遇到了我的主键序列与我的表行不同步的问题。
也就是说,当我插入一个新行时,我得到一个重复键错误,因为串行数据类型中隐含的序列返回一个已经存在的数字。
这似乎是由于导入/恢复没有正确维护顺序引起的。
原文由 meleyal 发布,翻译遵循 CC BY-SA 4.0 许可协议
我找不到 Rails 的明确答案。
从 rails console
ActiveRecord::Base.connection.execute("SELECT setval(pg_get_serial_sequence('table_name', 'id'), MAX(id)) FROM table_name;")
例如,将 table_name
替换为 --- users
。
原文由 NemyaNation 发布,翻译遵循 CC BY-SA 4.0 许可协议
1 回答2.6k 阅读✓ 已解决
3 回答2.4k 阅读
2 回答710 阅读✓ 已解决
2 回答1.1k 阅读
642 阅读
来源 - Ruby 论坛