欢迎投稿

今日深度:

PostgreSQL建立自增主键的2种方法总结,

PostgreSQL建立自增主键的2种方法总结,


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

    一、 准备工作

    首先创建一张表:

    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')

    总结 

    到此这篇关于PostgreSQL建立自增主键的2种方法的文章就介绍到这了,更多相关PostgreSQL建立自增主键内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!

    您可能感兴趣的文章:
    • PostgreSQL三种自增列sequence,serial,identity的用法区别
    • postgresql修改自增序列操作
    • PostgreSQL 自增语法的用法说明
    • PostgreSQL设置主键从1开始自增的详细步骤
    • PostgreSQL中实现自增的三种方式举例

    www.htsjk.Com true http://www.htsjk.com/shujukunews/47453.html NewsArticle PostgreSQL建立自增主键的2种方法总结, 目录 一、 准备工作 二、 第一种方法----创建序列达到自增的效果 1. 创建序列 2. 序列的相关方法 3. 插入数据 4. 设置默认值 三、第二种方法----使...
    评论暂时关闭