首页 > 数据库技术 > 详细

PostgreSQL 序列

时间:2016-09-09 15:16:36      阅读:320      评论:0      收藏:0      [点我收藏+]
PostgreSQL 中的序列是一个数据库对象,本质上是一个自增器。因此,序列在其他同类型数据库软件中以 autoincrment 值的形式存在。在一张表需要非随机,唯一标实符的场景下,Sequence 非常有用。
创建语法:
CREATE SEQUENCE sequencename
    [ INCREMENT increment ]        -- 自增数,默认是 1
    [ MINVALUE minvalue ]      -- 最小值
    [ MAXVALUE maxvalue ]      -- 最大值
    [ START start ]                -- 设置起始值
    [ CACHE cache ]                -- 是否预先缓存
    [ CYCLE ]                   -- 是否到达最大值的时候,重新返回到最小值
Sequence 使用的是整型数值,因此它的取值范围是 [-2147483647, 2147483647] 之间;

Sequence 的函数
Sequence 是不能被直接访问到的;他们需要通过 PostgreSQL 中的相关函数来操作他们。Sequence 的函数使用:
nextval(‘sequence_name‘): 将序列当前值设置成递增后的值,并返回;
currval(‘sequence_name‘): 返回序列当前值;
setval(‘sequence_name‘, n, b=true): 设置当前值;b 默认设置 true,下一次调用 nextval() 时,直接返回 n,如果设置 false,则返回 n+increment:
当数据库表序列插入冲突时,可使用下面的方法:
SELECT setval(‘your_table_id_seq‘, (SELECT MAX(id) FROM your_table)+1);
SELECT setval(‘your_table_id_seq‘, (SELECT MAX(id) FROM your_table),false);注意:获取表最大值的语句要加()才行。




PostgreSQL 序列

原文:http://www.cnblogs.com/doit8791/p/5856455.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!