本文介绍了有关PostgreSQL序列的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个关于PostgreSQL序列的问题。 例如,对于BigSerial数据类型,序列是前进的,然后检索编号,即使插入/提交不成功,序列也不会回溯。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。
在我的表上有一个BEFORE INSERT行触发器,而我使用的是心理Copg2。
提前谢谢。
推荐答案
即使插入/提交 不成功,序列不成功 走回头路。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。
是的,这是真的,这很好。 人们通常需要一个序列来获取表中唯一的值(通常是对于PK) 而差距一点也不重要。
如果您很好奇:如果考虑并发性,这是很自然的行为。假设事务T1插入一行,从一个序列中获取一个PK1,并使用该值在其他表中构建另一个记录...同时(在T1提交之前)另一个事务T2在同一个表中插入一行。然后T1回滚和T2提交...
顺便说一句:如果你想要一个"无间隙"的序列...首先问问自己,你是否真的想要它(通常你真的不想--而且这种要求经常会指向你的设计中的一个概念性问题)……但如果您真的需要它,您可以阅读this。这篇关于有关PostgreSQL序列的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!