PostgreSQL建立自增主鍵的兩種方法

AiTtang丨發表於2024-08-15

一、 準備工作

首先建立一張表:

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

相關文章