一、 準備工作
首先建立一張表:
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')