postgres序列mysql_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

Sequence "public.shipments_ship_id_seq&#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值