有关PostgreSQL序列的问题

question regarding postgresql sequences(有关PostgreSQL序列的问题)
本文介绍了有关PostgreSQL序列的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个关于PostgreSQL序列的问题。 例如,对于BigSerial数据类型,序列是前进的,然后检索编号,即使插入/提交不成功,序列也不会回溯。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。

在我的表上有一个BEFORE INSERT行触发器,而我使用的是心理Copg2。

提前谢谢。

推荐答案

即使插入/提交 不成功,序列不成功 走回头路。这意味着下一次我可能要插入到表中时,可能是序列号中的间隙。

是的,这是真的,这很好。 人们通常需要一个序列来获取表中唯一的值(通常是对于PK) 而差距一点也不重要。

如果您很好奇:如果考虑并发性,这是很自然的行为。假设事务T1插入一行,从一个序列中获取一个PK1,并使用该值在其他表中构建另一个记录...同时(在T1提交之前)另一个事务T2在同一个表中插入一行。然后T1回滚和T2提交...

顺便说一句:如果你想要一个"无间隙"的序列...首先问问自己,你是否真的想要它(通常你真的不想--而且这种要求经常会指向你的设计中的一个概念性问题)……但如果您真的需要它,您可以阅读this。

这篇关于有关PostgreSQL序列的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)