postgres查询序列_PostgreSQL之序列(Sequence)

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

Sequenc

你可能感兴趣的:(postgres查询序列)