首先创建一张表:
create table test( id int primary key, age int )
pgsql里,有种东西叫自增,很像mysql里的约束。建立一个自增的序列,每次需要获取自增主键时,调用一下这个序列就可以了。建立自增主键的序列的语法:
CREATE SEQUENCE test_id_seq INCREMENT 1 MINVALUE 1 MAXVALUE 9223372036854775807 START WITH 1 CACHE 1;
需要自增主键的时候,调用nextval(序列名)
就可以了:
test=# select nextval('test_id_seq'); nextval --------- 1
相关的方法如下(regclass 表示序列的名称):
函数 | 返回类型 | 描述 |
---|---|---|
currval( regclass ) | bigint | 获取指定序列最近一次使用netxval后的数值,如果没有使用nextval而直接使用currval会出错 |
lastval() | bigint | 返回最近一次用 nextval 获取的任意序列的数值 |
nextval( regclass ) | bigint | 递增序列并返回新值 |
setval( regclass,bigint ) | bigint | 设置序列的当前数值 |
setval( regclass,bigint ,boolean ) | bigint | 设置序列的当前数值以及 is_called 标志,如果为true则立即生效,如果为false,则调用一次nextval后才会生效 |
需要什么值就去找具体的函数就行了。
假设现在要向test表中插入数据,id自增,则:
insert into test values( nextval('test_id_seq') , 1 )
但是这种操作,每次都得写一遍序列名,很烦。不过有办法解决。看下面:
可以设置id字段的默认值为nextval(‘test_id_seq’),这样插入数据就不用每次都写一遍了。
alter table test -- 表名 alter column id -- 列名 set default nextval( 'test_id_seq' -- 序列名 );
再向test表中插入数据,这样写就行了:
insert into test(age) values(12)
或者直接:
insert into test values(12)
使用serial时,建表语句需要改一下:
create table test( id serial primary key, age int )
这时候,会自动创建名为表名_字段名_seq
的序列,且MAXVALUE=9223372036854775807,其余值为1。
例如,建立上表以后,则自动创建出名为test_id_seq
的序列。
插入数据,这样写就行了:
insert into test(age) values(12)
或者直接:
insert into test values(12)
使用如下sql可以获取序列当前值:
select currval('test_id_seq')