question regarding postgresql sequences(有关PostgreSQL序列的问题)
本文介绍了有关PostgreSQL序列的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个关于PostgreSQL序列的问题。 例如,对于BigSerial数据类型,序列是前进的,然后检索编号,即使插入/提交不成功,序列也不会回溯。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。
在我的表上有一个BEFORE INSERT行触发器,而我使用的是心理Copg2。
提前谢谢。
推荐答案
即使插入/提交 不成功,序列不成功 走回头路。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。
是的,这是真的,这很好。 人们通常需要一个序列来获取表中唯一的值(通常是对于PK) 而差距一点也不重要。
如果您很好奇:如果考虑并发性,这是很自然的行为。假设事务T1插入一行,从一个序列中获取一个PK1,并使用该值在其他表中构建另一个记录...同时(在T1提交之前)另一个事务T2在同一个表中插入一行。然后T1回滚和T2提交...
顺便说一句:如果你想要一个"无间隙"的序列...首先问问自己,你是否真的想要它(通常你真的不想--而且这种要求经常会指向你的设计中的一个概念性问题)……但如果您真的需要它,您可以阅读this。这篇关于有关PostgreSQL序列的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:有关PostgreSQL序列的问题
猜你喜欢
- 检查具有纬度和经度的地理点是否在 shapefile 中 2022-01-01
- 使用公司代理使Python3.x Slack(松弛客户端) 2022-01-01
- 我如何卸载 PyTorch? 2022-01-01
- 计算测试数量的Python单元测试 2022-01-01
- CTR 中的 AES 如何用于 Python 和 PyCrypto? 2022-01-01
- 如何使用PYSPARK从Spark获得批次行 2022-01-01
- YouTube API v3 返回截断的观看记录 2022-01-01
- 我如何透明地重定向一个Python导入? 2022-01-01
- 使用 Cython 将 Python 链接到共享库 2022-01-01
- ";find_element_by_name(';name';)";和&QOOT;FIND_ELEMENT(BY NAME,';NAME';)";之间有什么区别? 2022-01-01