Postgres处理自动递增的方式与MySQL稍有不同。在Postgres中,创建serial字段时,还创建了一个sequence字段,用于跟踪要使用的id。这个序列字段将以值1开始。
在表中插入新记录时,如果不指定id字段,它将使用序列的值,然后递增序列。但是,如果确实指定了id字段,则不会使用序列,也不会更新序列。
我假设,当你转到Postgres时,你已经播种或导入了一些现有的用户,以及他们现有的id。当您用这些用户的id创建这些用户记录时,序列没有被使用,因此它从未被更新。
因此,例如,如果导入了10个用户,则有ID为1-10的用户,但序列仍然是1。当您尝试在不指定id的情况下创建新用户时,它会从序列(1)中提取值,并且您会得到一个唯一的冲突,因为您已经有一个id为1的用户。
要解决此问题,需要将users\ id\ seq sequence值设置为现有用户的MAX(id)。可以尝试以下操作(未测试):
SELECT setval(pg_get_serial_sequence('users', 'id'), coalesce(max(id)+1,1), false) FROM users;