PostgreSQL建立自增主键的两种方法
创始人
2024-11-30 15:35:04
0

一、 准备工作

首先创建一张表:

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;  
  1. INCREMENT BY : 每次序列增加(或减少)的步长
  2. MINVALUE : 序列最小值,NO MINVALUE表示没有最小值
  3. MAXVALUE : 序列最大值,NO MAXVALUE表示没有最大值
  4. START WITH :以什么序列值开始
  5. CYCLE : 序列是否循环使用
  6. 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') 

相关内容

热门资讯

第2分钟操作!圣游科技辅助器,... 第2分钟操作!圣游科技辅助器,随意玩房卡辅助器透视(辅助)本来有挂平台(哔哩哔哩)1、随意玩房卡辅助...
五分钟手筋!好友赣南新版本挂,... 您好,好友赣南新版本挂这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩...
五分钟手筋!贰柒拾智能辅助柒,... 五分钟手筋!贰柒拾智能辅助柒,新广西老友辅助(辅助)其实存在有插件(哔哩哔哩)进入游戏-大厅左侧-新...
7分钟举措!丫丫衡阳字牌3辅助... 7分钟举措!丫丫衡阳字牌3辅助,樱花之盛辅助器下载(辅助)一贯是真的平台(哔哩哔哩)1、7分钟举措!...
第3分钟教程书!掌电竞技辅助器... 第3分钟教程书!掌电竞技辅助器,悟空大厅辅助器(辅助)一贯是有辅助器(哔哩哔哩)1)掌电竞技辅助器辅...
第2分钟法子!哈糖大菠萝可以开... 第2分钟法子!哈糖大菠萝可以开挂吗,悟空大厅辅助器下载(辅助)确实真的是有软件(哔哩哔哩)1、进入到...
第五分钟机巧!闲逸软件可以控制... 第五分钟机巧!闲逸软件可以控制的吗,新众亿挂机(辅助)都是是有神器(哔哩哔哩)第五分钟机巧!闲逸软件...
1分钟绝活!悠闲卡五星辅助,来... 1分钟绝活!悠闲卡五星辅助,来来拼十辅助(辅助)本来存在有下载(哔哩哔哩)1、悠闲卡五星辅助免费脚本...
第4分钟技法!边锋干瞪眼小程序... 第4分钟技法!边锋干瞪眼小程序辅助,道游互娱辅助免费版(辅助)本来真的有辅助器(哔哩哔哩)1、玩家可...
脚本曝光!hhpoker俱乐部... 脚本曝光!hhpoker俱乐部是干嘛的,hhpoker辅助软件(透视)切实真的有神器(哔哩哔哩)1、...