postgres序列mysql_PostgreSQL之序列(Sequence)

本文介绍了PostgreSQL中的序列(Sequence)概念,它是一个自增器,常用于生成表的唯一标识符。文章详细讲解了创建、查看、使用和删除序列的操作,包括nextval()、currval()和setval()函数的用法,并提供了示例。
摘要由CSDN通过智能技术生成

Postgresql 中的序列是一个数据库对象,本质上是一个自增器。因此,序列在其他同类型数据库软件中以 autoincrment 值的形式存在。在一张表需要非随机,唯一标实符的场景下,Sequence 非常有用。

Sequence 对象中包含当前值,和一些独特属性,例如如何递增(或者递减)。实际上,Sequence 是不能被直接访问到的;他们需要通过 Postgresql 中的相关函数来操作他们。

创建序列

看看创建的语法:

CREATE SEQUENCE sequencename

[ INCREMENT increment ] -- 自增数,默认是 1

[ MINVALUE minvalue ] -- 最小值

[ MAXVALUE maxvalue ] -- 最大值

[ START start ] -- 设置起始值

[ CACHE cache ] -- 是否预先缓存

[ CYCLE ] -- 是否到达最大值的时候,重新返回到最小值

Sequence 使用的是整型数值,因此它的取值范围是 [-2147483647,2147483647] 之间;现在我们创建一个简单的序列:

pigdb> CREATE SEQUENCE shipments_ship_id_seq

MINVALUE 0;

CREATE SEQUENCE

查看序列

psql 的 \d 命令输出一个数据库对象,包括 Sequence,表,视图和索引。你还可以使用 \ds 命令只查看当前数据库的所有序列。例如:

pigdb-# \ds

List of relations

Schema | Name | Type | Owner

--------+-----------------------+----------+--------

public | author_ids | sequence | ichexw

public | shipments_ship_id_seq | sequence | ichexw

(2 rows)

Sequence 就像表和视图一样,拥有自己的结构,只不过它的结构是固定的:

pigdb=# \d shipments_ship_id_seq

Sequence "public.shipments_ship_id_seq&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值