question regarding postgresql sequences(有关PostgreSQL序列的问题)
本文介绍了有关PostgreSQL序列的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个关于PostgreSQL序列的问题。 例如,对于BigSerial数据类型,序列是前进的,然后检索编号,即使插入/提交不成功,序列也不会回溯。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。
在我的表上有一个BEFORE INSERT行触发器,而我使用的是心理Copg2。
提前谢谢。
推荐答案
即使插入/提交 不成功,序列不成功 走回头路。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。
是的,这是真的,这很好。 人们通常需要一个序列来获取表中唯一的值(通常是对于PK) 而差距一点也不重要。
如果您很好奇:如果考虑并发性,这是很自然的行为。假设事务T1插入一行,从一个序列中获取一个PK1,并使用该值在其他表中构建另一个记录...同时(在T1提交之前)另一个事务T2在同一个表中插入一行。然后T1回滚和T2提交...
顺便说一句:如果你想要一个"无间隙"的序列...首先问问自己,你是否真的想要它(通常你真的不想--而且这种要求经常会指向你的设计中的一个概念性问题)……但如果您真的需要它,您可以阅读this。这篇关于有关PostgreSQL序列的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:有关PostgreSQL序列的问题
基础教程推荐
猜你喜欢
- Python,确定字符串是否应转换为 Int 或 Float 2022-01-01
- Kivy 使用 opencv.调整图像大小 2022-01-01
- 究竟什么是“容器"?在蟒蛇?(以及所有的 python 容器类型是什么?) 2022-01-01
- 比较两个文本文件以找出差异并将它们输出到新的文本文件 2022-01-01
- 对多索引数据帧的列进行排序 2022-01-01
- Python 中是否有任何支持将长字符串转储为块文字或折叠块的 yaml 库? 2022-01-01
- kivy 应用程序中的一个简单网页作为小部件 2022-01-01
- matplotlib 设置 yaxis 标签大小 2022-01-01
- 在 Python 中将货币解析为数字 2022-01-01
- 在 Django Admin 中使用内联 OneToOneField 2022-01-01
