更新时间:2024-11-01 GMT+08:00
分享

SEQUENCE函数

序列函数为用户从序列对象中获取后续的序列值提供了简单的多用户安全的方法。

  • nextval(regclass)

    描述:递增序列并返回新值。

    为了避免从同一个序列获取值的并发事务被阻塞,nextval操作不会回滚;即一旦值被抓取,就认为它已经被用过,并且不会再被返回。即使该操作处于事务中,当事务之后中断,或者如果调用查询结束不使用该值,也是如此。这种情况将在指定值的顺序中留下未使用的“空洞”。因此,GaussDB序列对象不能用于获得“无间隙”序列。

    nextval函数只能在主机上执行,备机不支持执行此函数。

    返回类型:numeric

    nextval函数有两种调用方式(其中第二种调用方式目前不支持Sequence命名中有特殊字符"."的情况),如下:

     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    13
    14
    gaussdb=# CREATE SEQUENCE seqDemo;
    --示例1:
    gaussdb=# SELECT nextval('seqDemo'); 
     nextval
    ---------
           1
    (1 row)
    --示例2:
    gaussdb=# SELECT seqDemo.nextval; 
     nextval
    ---------
           2
    (1 row)
    gaussdb=# DROP SEQUENCE seqDemo;
    
  • currval(regclass)

    描述:返回当前会话里最近一次nextval返回的数值。如果当前会话还没有调用过指定的sequence的nextval,那么调用currval将会报错。

    返回类型:numeric

    currval函数有两种调用方式(其中第二种调用方式目前不支持Sequence命名中有特殊字符"."的情况),如下:

     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    13
    14
    15
    gaussdb=# CREATE SEQUENCE seq1;
    gaussdb=# SELECT nextval('seq1'); 
    --示例1:
    gaussdb=# SELECT currval('seq1'); 
     currval
    ---------
           1
    (1 row)
    --示例2:
    gaussdb=# SELECT seq1.currval; 
     currval
    ---------
           1
    (1 row)
    gaussdb=# DROP SEQUENCE seq1;
    
  • lastval()

    描述:返回当前会话里最近一次nextval返回的数值。这个函数等效于currval,只是它不用序列名为参数,它抓取当前会话里面最近一次nextval使用的序列。如果当前会话还没有调用过nextval,那么调用lastval将会报错。

    返回类型:numeric

    示例:

    1
    2
    3
    4
    5
    6
    7
    8
    gaussdb=# CREATE SEQUENCE seq1;
    gaussdb=# SELECT nextval('seq1'); 
    gaussdb=# SELECT lastval(); 
     lastval
    ---------
           1
    (1 row)
    gaussdb=# DROP SEQUENCE seq1;
    
  • setval(regclass, numeric)

    描述:设置序列的当前数值。

    返回类型:numeric

    示例:

    1
    2
    3
    4
    5
    6
    7
    8
    gaussdb=# CREATE SEQUENCE seqDemo;
    gaussdb=# SELECT nextval('seqDemo'); 
    gaussdb=# SELECT setval('seqDemo',5);
     setval
    --------
          5
    (1 row)
    gaussdb=# DROP SEQUENCE seqDemo;
    
  • setval(regclass, numeric, Boolean)

    描述:设置序列的当前数值以及is_called标志。

    返回类型:numeric

    示例:

    1
    2
    3
    4
    5
    6
    7
    8
    gaussdb=# CREATE SEQUENCE seqDemo;
    gaussdb=# SELECT nextval('seqDemo'); 
    gaussdb=# SELECT setval('seqDemo',5,true);
     setval
    --------
          5
    (1 row)
    gaussdb=# DROP SEQUENCE seqDemo;
    

    Setval后当前会话会立刻生效,但如果其他会话有缓存的序列值,只能等到缓存值用尽才能感知Setval的作用。所以为了避免序列值冲突,setval要谨慎使用。

    因为序列是非事务的,setval造成的改变不会由于事务的回滚而撤销。

    nextval函数只能在主机上执行,备机不支持执行此函数。

  • pg_sequence_last_value(sequence_oid oid, OUT cache_value int16, OUT last_value int16)

    描述:获取指定sequence的参数,包含缓存值、当前值。

    返回类型:int16,int16

  • gs_get_sequence_last_value(sequence_oid oid, OUT cache_value int16, OUT last_value int16)

    描述:获取指定sequence的参数,包含缓存值、当前值。该函数针对无权限的sequence返回null值。

    返回类型:int16,int16

  • last_insert_id()

    描述:获取最近一次为自动增长列成功插入的第一个自动生成的值。

    返回类型:int16

  • last_insert_id(int16)

    描述:设置下一次last_insert_id()函数的返回值,并返回此值。若参数为NULL,将下一次last_insert_id()函数的返回值设为0,此函数返回NULL。

    返回值类型:int16

    示例:

     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    13
    14
    gaussdb=# create database b_format_db with dbcompatibility = 'b';
    gaussdb=# \c b_format_db;
    b_format_db=#SELECT last_insert_id(100);
     last_insert_id
    ----------------
                100
    (1 row)
    b_format_db=#SELECT last_insert_id();
     last_insert_id
    ----------------
                100
    (1 row)
    b_format_db=# \c postgres;
    gaussdb=# DROP DATABASE b_format_db;
    
    • last_insert_id()和last_insert_id(int16)是会话级别的函数,若当前会话未对自动增长列插入任何数据,last_insert_id()返回值为0。
    • last_insert_id()和last_insert_id(int16)仅在参数sql_compatibility='B'时可用。

相关文档