PostgreSQL如何建立自增主键 , PostgreSQL建立自增主键的两种方法

    技术2024-03-13  90

    文章目录

    一、 准备工作二、 第一种方法----创建序列达到自增的效果1. 创建序列2. 序列的相关方法3. 插入数据4. 设置默认值 三、第二种方法----使用SERIAL1. 建表语句2. 插入数据3. 如何获取序列的当前值

                 以前建立自增主键都是用mysql建的,只要写个 auto_increment就行了,最近因为工作,需要用到PostgreSQL的自增主键,就去了解了下。发现网上的这点东西写的真乱…就没有个说是整整齐齐从头到尾说清楚的,没有就只能我自己写了…       首先,pgsql没有auto_increment这么一说,所以想要建立自增主键就得想想其他办法了

    一、 准备工作

          首先创建一张表:

    create table test( id int primary key, age int )

          

    二、 第一种方法----创建序列达到自增的效果

    1. 创建序列

          pgsql里,有种东西叫自增,很像mysql里的约束。建立一个自增的序列,每次需要获取自增主键时,调用一下这个序列就可以了。       建立自增主键的序列的语法:

    CREATE SEQUENCE test_id_seq INCREMENT 1 MINVALUE 1 MAXVALUE 9223372036854775807 START WITH 1 CACHE 1;

                 INCREMENT BY : 每次序列增加(或减少)的步长       MINVALUE : 序列最小值,NO MINVALUE表示没有最小值       MAXVALUE : 序列最大值,NO MAXVALUE表示没有最大值       START WITH :以什么序列值开始       CYCLE : 序列是否循环使用       OWNED BY : 可以直接指定一个表的字段,也可以不指定。              需要自增主键的时候,调用nextval(序列名)就可以了:

    test=# select nextval('test_id_seq'); nextval --------- 1

    2. 序列的相关方法

          相关的方法如下(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后才会生效

          需要什么值就去找具体的函数就行了。

    3. 插入数据

          假设现在要向test表中插入数据,id自增,则:

    insert into test values( nextval('test_id_seq') , 1 )

          但是这种操作,每次都得写一遍序列名,很烦。不过有办法解决。看下面:

    4. 设置默认值

          可以设置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

    1. 建表语句

          使用serial时,建表语句需要改一下:

    create table test( id serial primary key, age int )

          这时候,会自动创建名为表名_字段名_seq的序列,且MAXVALUE=9223372036854775807,其余值为1。       例如,建立上表以后,则自动创建出名为test_id_seq的序列。       

    2. 插入数据

          插入数据,这样写就行了:

    insert into test(age) values(12)

          或者直接:

    insert into test values(12)

          

    3. 如何获取序列的当前值

          使用如下sql可以获取序列当前值:

    select currval('test_id_seq')

          一些其他情况可以看这里: 如何获取序列当前值?以及如何解决相关报错

    Processed: 0.012, SQL: 9