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

 更新时间:2023年09月28日 16:25:17   作者:AiTtang  
这篇文章主要给大家介绍了关于PostgreSQL建立自增主键的2种方法,PostgreSQL主键自增是一种自动增长的机制,可以为表中的每一行记录分配唯一的标识符,需要的朋友可以参考下

一、 准备工作

首先创建一张表:

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建立自增主键内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • postgresql数据库导出和导入及常用的数据库管理工具

    postgresql数据库导出和导入及常用的数据库管理工具

    数据库的导入导出是最常用的功能之一,而PostgreSQL提供的对应工具为pg_dump和pg_restore。pg_dump是用于备份PostgreSQL数据库的工具,下面这篇文章主要给大家介绍了关于postgresql数据库导出和导入及常用的数据库管理工具使用的相关资料,需要的朋友可以参考下
    2023-04-04
  • PostgreSQL中数据批量导入导出的错误处理

    PostgreSQL中数据批量导入导出的错误处理

    在 PostgreSQL 中进行数据的批量导入导出是常见的操作,但有时可能会遇到各种错误,下面将详细探讨可能出现的错误类型、原因及相应的解决方案,并提供具体的示例来帮助您更好地理解和处理这些问题,需要的朋友可以参考下
    2024-07-07
  • PostgreSQL使用MySQL作为外部表(mysql_fdw)

    PostgreSQL使用MySQL作为外部表(mysql_fdw)

    PostgreSQL 提供了一种访问和操作外部数据源的机制,称为外部数据包装器,本文主要给大家介绍了PostgreSQL使用MySQL作为外部表的方法,感兴趣的朋友跟随小编一起看看吧
    2022-11-11
  • PostgreSQL慢SQL的定位排查方法

    PostgreSQL慢SQL的定位排查方法

    所谓慢SQL 是指在数据库中执行时间超过指定阈值的语句,慢查询太多,对于业务而言,是有很大风险的,可能随时都会因为某种原因而被触发,本篇文章将介绍 PostgreSQL 慢 SQL 如何定位排查,需要的朋友可以参考下
    2024-07-07
  • postgreSQL数据库的监控及数据维护操作

    postgreSQL数据库的监控及数据维护操作

    这篇文章主要介绍了postgreSQL数据库的监控及数据维护操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL表膨胀监控案例(精确计算)

    PostgreSQL表膨胀监控案例(精确计算)

    这篇文章主要介绍了PostgreSQL表膨胀监控案例(精确计算),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • pgsql 如何手动触发归档

    pgsql 如何手动触发归档

    这篇文章主要介绍了pgsql手动触发归档的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • postgresql如何查询重复计数及去重查询

    postgresql如何查询重复计数及去重查询

    这篇文章主要介绍了postgresql如何查询重复计数及去重查询问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • postgresql 赋权语句 grant的正确使用说明

    postgresql 赋权语句 grant的正确使用说明

    这篇文章主要介绍了postgresql 赋权语句 grant的正确使用说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • Linux CentOS 7源码编译安装PostgreSQL9.5

    Linux CentOS 7源码编译安装PostgreSQL9.5

    这篇文章主要为大家详细介绍了Linux CentOS 7源码编译安装PostgreSQL9.5的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11

最新评论