1. 问题的提出 PostgreSQL定义TABLE时,主键的字段类型可以设定为自增类型serial,即插入每条记录时,主键的值自动加1.但是,当插入数据的时候指定了具体的主键值,例如主键值从0到500,这时主键的序列值不会跟着更新到500.那么以后再自动生成主键序列值时,会出现因为主键序列值重复而无法插入新的记录的问题. 2. 解决的方法 首先使用MAX函数查询目前表中最大的主键值,然后使用setval函数把最大主键值设置为当前的序列值. 假设表名为ApplicationRunInfo, 主键