PostgreSQL如何建立自增主鍵

      
      以前建立自增主鍵都是用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)

      
      
      

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章