有关PostgreSQL序列的问题
问题描述
我有一个关于PostgreSQL序列的问题。
例如,对于BigSerial数据类型,序列是前进的,然后检索编号,即使插入/提交不成功,序列也不会回溯。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。在我的表上有一个BEFORE INSERT行触发器,而我使用的是心理Copg2。
提前谢谢。
解决方案
即使插入/提交 不成功,序列不成功 走回头路。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。
是的,这是真的,这很好。 人们通常需要一个序列来获取表中唯一的值(通常是对于PK) 而差距一点也不重要。
如果您很好奇:如果考虑并发性,这是很自然的行为。假设事务T1插入一行,从一个序列中获取一个PK1,并使用该值在其他表中构建另一个记录...同时(在T1提交之前)另一个事务T2在同一个表中插入一行。然后T1回滚和T2提交...
顺便说一句:如果你想要一个"无间隙"的序列...首先问问自己,你是否真的想要它(通常你真的不想--而且这种要求经常会指向你的设计中的一个概念性问题)……但如果您真的需要它,您可以阅读this。相关文章