以前建立自增主鍵都是用mysql建的,只要寫個 auto_increment就行了,最近因爲工作,需要用到PostgreSQL的自增主鍵,就去了解了下。發現網上的這點東西寫的真亂…就沒有個說是整整齊齊從頭到尾說清楚的,沒有就只能我自己寫了…
首先,pgsql沒有auto_increment這麼一說,所以想要建立自增主鍵就得想想其他辦法了
一、 準備工作
首先創建一張表:
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. 序列的相關方法
相關的方法如下:
函 數 | 返 回 類 型 | 描 述 |
---|---|---|
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)