PostgreSQL建立自增主鍵的2種方法總結(jié)
一、 準(zhǔn)備工作
首先創(chuàng)建一張表:
create table test( id int primary key, age int )
二、 第一種方法----創(chuàng)建序列達(dá)到自增的效果
1. 創(chuàng)建序列
pgsql里,有種東西叫自增,很像mysql里的約束。建立一個(gè)自增的序列,每次需要獲取自增主鍵時(shí),調(diào)用一下這個(gè)序列就可以了。建立自增主鍵的序列的語(yǔ)法:
CREATE SEQUENCE test_id_seq INCREMENT 1 MINVALUE 1 MAXVALUE 9223372036854775807 START WITH 1 CACHE 1;
- INCREMENT BY : 每次序列增加(或減少)的步長(zhǎng)
- MINVALUE : 序列最小值,NO MINVALUE表示沒有最小值
- MAXVALUE : 序列最大值,NO MAXVALUE表示沒有最大值
- START WITH :以什么序列值開始
- CYCLE : 序列是否循環(huán)使用
- OWNED BY : 可以直接指定一個(gè)表的字段,也可以不指定。
需要自增主鍵的時(shí)候,調(diào)用nextval(序列名)
就可以了:
test=# select nextval('test_id_seq'); nextval --------- 1
2. 序列的相關(guān)方法
相關(guān)的方法如下(regclass 表示序列的名稱):
函數(shù) | 返回類型 | 描述 |
---|---|---|
currval( regclass ) | bigint | 獲取指定序列最近一次使用netxval后的數(shù)值,如果沒有使用nextval而直接使用currval會(huì)出錯(cuò) |
lastval() | bigint | 返回最近一次用 nextval 獲取的任意序列的數(shù)值 |
nextval( regclass ) | bigint | 遞增序列并返回新值 |
setval( regclass,bigint ) | bigint | 設(shè)置序列的當(dāng)前數(shù)值 |
setval( regclass,bigint ,boolean ) | bigint | 設(shè)置序列的當(dāng)前數(shù)值以及 is_called 標(biāo)志,如果為true則立即生效,如果為false,則調(diào)用一次nextval后才會(huì)生效 |
需要什么值就去找具體的函數(shù)就行了。
3. 插入數(shù)據(jù)
假設(shè)現(xiàn)在要向test表中插入數(shù)據(jù),id自增,則:
insert into test values( nextval('test_id_seq') , 1 )
但是這種操作,每次都得寫一遍序列名,很煩。不過(guò)有辦法解決??聪旅妫?/p>
4. 設(shè)置默認(rèn)值
可以設(shè)置id字段的默認(rèn)值為nextval(‘test_id_seq’),這樣插入數(shù)據(jù)就不用每次都寫一遍了。
alter table test -- 表名 alter column id -- 列名 set default nextval( 'test_id_seq' -- 序列名 );
再向test表中插入數(shù)據(jù),這樣寫就行了:
insert into test(age) values(12)
或者直接:
insert into test values(12)
三、第二種方法----使用SERIAL
1. 建表語(yǔ)句
使用serial時(shí),建表語(yǔ)句需要改一下:
create table test( id serial primary key, age int )
這時(shí)候,會(huì)自動(dòng)創(chuàng)建名為表名_字段名_seq
的序列,且MAXVALUE=9223372036854775807,其余值為1。
例如,建立上表以后,則自動(dòng)創(chuàng)建出名為test_id_seq
的序列。
2. 插入數(shù)據(jù)
插入數(shù)據(jù),這樣寫就行了:
insert into test(age) values(12)
或者直接:
insert into test values(12)
3. 如何獲取序列的當(dāng)前值
使用如下sql可以獲取序列當(dāng)前值:
select currval('test_id_seq')
總結(jié)
到此這篇關(guān)于PostgreSQL建立自增主鍵的2種方法的文章就介紹到這了,更多相關(guān)PostgreSQL建立自增主鍵內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PostgreSQL的整型、浮點(diǎn)型、固定精度數(shù)值和序列等數(shù)字類型
PostgreSQL(簡(jiǎn)稱PGSQL)是一種開源關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),廣泛應(yīng)用于企業(yè)級(jí)應(yīng)用,文章詳細(xì)介紹了PostgreSQL的數(shù)字類型,包括整型、浮點(diǎn)型、固定精度數(shù)值型和序列類型,強(qiáng)調(diào)了選擇合適的數(shù)字類型對(duì)于數(shù)據(jù)庫(kù)的存儲(chǔ)效率、查詢性能和數(shù)據(jù)準(zhǔn)確性的重要性2024-09-09PostgreSQL如何按照某一字段去重,并顯示其他字段信息
這篇文章主要介紹了PostgreSQL如何按照某一字段去重,并顯示其他字段信息問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05詳解如何在Ubuntu?18.04上安裝和使用PostgreSQL
關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)是許多網(wǎng)站和應(yīng)用程序的關(guān)鍵組件,它們提供了一種結(jié)構(gòu)化的方式來(lái)存儲(chǔ)、組織和訪問(wèn)信息,本文演示了如何在?Ubuntu?18.04?VPS?實(shí)例上安裝?Postgres,并提供了基本數(shù)據(jù)庫(kù)管理的說(shuō)明,需要的朋友可以參考下2024-07-07PostgreSQL數(shù)據(jù)庫(kù)事務(wù)實(shí)現(xiàn)方法分析
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫(kù)事務(wù)實(shí)現(xiàn)方法,簡(jiǎn)單講述了事務(wù)的概念、功能,并結(jié)合實(shí)例形式分析了PostgreSQL數(shù)據(jù)庫(kù)事務(wù)的定義方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2018-08-08postgresql 實(shí)現(xiàn)sql多行語(yǔ)句合并一行
這篇文章主要介紹了postgresql 實(shí)現(xiàn)sql多行語(yǔ)句合并一行的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12使用pg_basebackup對(duì)Postgre進(jìn)行備份與恢復(fù)的實(shí)現(xiàn)
這篇文章主要介紹了使用pg_basebackup對(duì)Postgre進(jìn)行備份與恢復(fù)的實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01postgreSql分組統(tǒng)計(jì)數(shù)據(jù)的實(shí)現(xiàn)代碼
這篇文章給大家介紹postgreSql的監(jiān)控記錄表里多條不同時(shí)間的數(shù)據(jù),只取最新的數(shù)據(jù),并分組統(tǒng)計(jì),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-12-12