PostgreSQL serial类型

news/2024/7/9 20:40:09 标签: postgresql

serial类型和序列

postgresql序列号(SERIAL)类型包括

  • smallserial(smallint,short),
  • serial(int)
  • bigserial(bigint,long long int)

不管是smallserial,serial还是bigserial,其范围都是(1,9223372036854775807),但是序列号类型其实不是真正的类型,当声明一个字段为序列号类型时其实是创建了一个序列,INSERT时如果没有给该字段赋值会默认获取对应序列的下一个值。

操作

建表的时添加序列

create table tbl_serial(a serial,b varchar(2));

单独创建序列再使用

 create sequence sql_tbl_serial2_a 
increment by 1 
minvalue 1 
no maxvalue 
start with 1;


create table tbl_serial2(
    a int not null default nextval('sql_tbl_serial2_a'),
    b varchar(2)
);

创建序列

Syntax:
CREATE [ TEMPORARY | TEMP ] SEQUENCE [ IF NOT EXISTS ] name [ INCREMENT [ BY ] increment ]
    [ MINVALUE minvalue | NO MINVALUE ] [ MAXVALUE maxvalue | NO MAXVALUE ]
    [ START [ WITH ] start ] [ CACHE cache ] [ [ NO ] CYCLE ]
    [ OWNED BY { table_name.column_name | NONE } ]

INCREMENT BY : 每次序列增加(或减少)的步长

MINVALUE : 序列最小值,NO MINVALUE表示没有最小值

MAXVALUE : 序列最大值,NO MAXVALUE表示没有最大值

START WITH :以什么序列值开始

CYCLE : 序列是否循环使用

OWNED BY : 可以直接指定一个表的字段,也可以不指定。

需要改序列

Syntax:
ALTER SEQUENCE [ IF EXISTS ] name [ INCREMENT [ BY ] increment ]
    [ MINVALUE minvalue | NO MINVALUE ] [ MAXVALUE maxvalue | NO MAXVALUE ]
    [ START [ WITH ] start ]
    [ RESTART [ [ WITH ] restart ] ]
    [ CACHE cache ] [ [ NO ] CYCLE ]
    [ OWNED BY { table_name.column_name | NONE } ]

序列涉及的函数有

函 数返 回 类 型描 述
currval( regclass )bigint获取指定序列最近一次使用netxval后的数值,如果没有使用nextval而直接使用currval会出错。
lastval()bigint返回最近一次用 nextval 获取的任意序列的数值
nextval( regclass )bigint递增序列并返回新值
setval( regclass,bigint )bigint设置序列的当前数值
setval( regclass,bigint ,boolean )bigint设置序列的当前数值以及 is_called 标志,如果为true则立即生效,如果为false,则调用一次nextval后才会生效。

重命名

我有一个名为pivot_device_user的表,它的ID为not null default nextval(‘pivot_device_user_id_seq’::regclass)。在Postgres中重命名为nextval(‘…’)

然后我决定将我的表重命名为pivot_box_user,但nextval(…)仍然是nextval(‘pivot_device_user_id_seq’::regclass)。我想将它更改为nextval(‘pivot_box_user_id_seq’::regclass)。

如果您重命名序列,则其OID保持不变。因此,所有你需要做的是rename the sequence:

ALTER SEQUENCE pivot_device_user_id_seq RENAME TO pivot_box_user_id_seq; 

查询当前序列值

SELECT currval('sequence_name'::regclass);

使用当前序列值,下个序列值递增

SELECT nextval('sequence_name'::regclass);

问题

如果一个序列是NO CYCLE,当序列值全部使用完会怎样呢?

如果序列值用完了当然是错误了!!!如果是CYCLE则会重新从START处开始再次循环。


http://www.niftyadmin.cn/n/5035244.html

相关文章

fire-voc 火光 烟火 火灾 目标检测数据集

一年中最容易引发火灾的季节是在冬季,主要原因有这样几点。 1、秋冬季节,随着用火、用电、用气增加,加上天气干燥,棉花、木材 、衣物等物体内含有的水分也较低。2、秋冬季风力较大,一旦有火苗冒起就很容易随风蔓延,是火灾的高发期。3、春季也是火灾多发季节&#x…

深度学习之模型压缩、加速模型推理

简介 当将一个机器学习模型部署到生产环境中时,通常需要满足一些在模型原型阶段没有考虑到的要求。例如,在生产中使用的模型将不得不处理来自不同用户的大量请求。因此,您将希望进行优化,以获得较低的延迟和/或吞吐量。 延迟&…

python读取CSV文件并生成折线图

Python是一门非常强大的编程语言,能够处理各种各样的数据。CSV(Comma-Separated Values)是一种常见的文件格式,经常用于存储和交换数据,特别是在数据分析和数据处理领域。在这篇文章中,我们将通过使用Pytho…

微服务下怎么做权限管理

微服务下怎么做权限管理 应用拆分微服务后,一个不可避免的问题就是权限问题。拆分后的各个微服务如何处理权限,怎么处理才能保证满足业务的需求,怎么处理才能保持架构的简单及可维护?今天的文章,让我们来深入微服务架构…

python开发之个微群聊机器人的开发

简要描述: 退出群聊 请求URL: http://域名地址/quitChatRoom 请求方式: POST 请求头Headers: Content-Type:application/jsonAuthorization:login接口返回 参数: 参数名必选类型说明wI…

Java-List<Map>的复制 深拷贝与浅拷贝

博客背景是Java开发。讲一讲List< Map>的复制中深拷贝与浅拷贝。 文章目录 1、浅拷贝1.1循环遍历复制1.2 使用list实现类的构造方法1.3 addAll方法 2、深拷贝深拷贝工具类 SerializationUtils.clone 1、浅拷贝 Map除了基本类型是值传递&#xff0c;其余的都是引用地址传…

RNN简介(深入浅出)

目录 简介1. 基本理论 简介 要快速掌握RNN&#xff0c;可以考虑以下步骤&#xff1a; 学习基本理论&#xff1a;了解RNN的原理、结构和工作原理。掌握RNN的输入输出形式、时间步、隐藏状态、记忆单元等关键概念。学习常见的RNN变体&#xff1a;了解LSTM&#xff08;Long Shor…

四、Mediasoup Js和 C++ 管道通信的过程

整体分为两部分 1、 js对c读写消息&#xff0c;_consumerSocket和producerSocket 2、c对js读写消息&#xff0c;c收到都是底层都是通过libuv的uv_read_start和uv_write 目录 一、js接收c数据 二、js主动调用c&#xff0c;通过producerSocket.write 三、C底层读取JS数据 …