在PostgreSQL中設(shè)置表中某列值自增或循環(huán)方式
在postgresql中,設(shè)置已存在的某列(num)值自增,可以用以下方法:
//將表tb按name排序,利用row_number() over()查詢序號并將該列命名為rownum,創(chuàng)建新表tb1并將結(jié)果保存到該表中 create table tb1 as (select *, row_number() over(order by name) as rownum from tb); //根據(jù)兩張表共同的字段name,將tb1中rownum對應(yīng)值更新到tb中num中 update tb set num=(select tb1.rownum from tb1 where tb.name = tb1.name); //判斷表tb1的存在并刪除表 drop table if exists tb1;
在postgresql中,循環(huán)設(shè)置已存在的某列(num)值為0-9,可以用以下方法:
//將表tb按name排序,利用row_number() over()查詢序號并將該列命名為rownum,創(chuàng)建新表tb1并將結(jié)果保存到該表中 create table tb1 as (select *, row_number() over(order by name) as rownum from tb); //根據(jù)兩張表共同的字段name,將tb1中rownum對應(yīng)值更新到tb中num中,由于為0-9循環(huán)自增,則%10 update tb set num=(select tb1.rownum from tb1 where tb.name = tb1.name) % 10; //判斷表tb1的存在并刪除表 drop table if exists tb1;
其它:附錄一個postgresql循環(huán)的寫法(與上文無關(guān))
do $$ declare v_idx integer :=0; begin while v_idx < 10 loop update tb set num = v_idx; v_idx = v_idx + 1; end loop; end $$;
補充:postgreSQL SQL語句創(chuàng)建自增表
方法一:postgreSQL通過將字段類型設(shè)置為serial來將表設(shè)計為自增表
CREATE TABLE t_achievement_directory ( id serial8 PRIMARY KEY, directory_name varchar(255) COLLATE "pg_catalog"."default", pid int8, modify_time timestamp(6) ) ;
方法二:GENERATED BY ALWAYS AS IDENTITY 或 GENERATED BY DEFAULT AS IDENTITY
id int8 NOT NULL GENERATED BY DEFAULT AS IDENTITY
或
id int8 NOT NULL GENERATED ALWAYS AS IDENTITY
這兩種方式的區(qū)別在于:
generated always as identity 總是按照(START WITH 1 INCREMENT BY 1)的方式插入數(shù)據(jù),并維護索引。即不允許用戶向id列指定數(shù)據(jù)插入。
但是 generated by default as identity 則是在用戶不指定id列值的情況下按照(START WITH 10 INCREMENT BY 10)方式插入數(shù)據(jù),如果用戶指定,則依然按照指定的值插入。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
如何使用Dockerfile創(chuàng)建PostgreSQL數(shù)據(jù)庫
這篇文章主要介紹了如何使用Dockerfile創(chuàng)建PostgreSQL數(shù)據(jù)庫,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-02-02
CentOS 7下安裝PostgreSQL 9.6的教程分享
PostgreSQL在我心目中的地位要遠遠高于MySQL,雖然流行對比MySQL低很對,但是功能性一致走在MySQL的前面。下面這篇文章主要介紹了CentOS 7下安裝PostgreSQL數(shù)據(jù)庫的方法,需要的朋友可以參考借鑒,一起來看看吧。2017-02-02
PostgreSQL數(shù)據(jù)庫遷移部署實戰(zhàn)教程
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫遷移部署實戰(zhàn)教程,由于項目本身就是基于PostgreSQL數(shù)據(jù)庫構(gòu)建的,因此數(shù)據(jù)庫遷移將變得十分便捷,接下來,我將簡要介紹我們的遷移步驟,需要的朋友可以參考下2023-07-07
解決PostgreSQL服務(wù)啟動后占用100% CPU卡死的問題
前文書說到,今天耗費了九牛二虎之力,終于馴服了NTFS權(quán)限安裝好了PostgreSQL,卻不曾想,服務(wù)啟動后,新的狀況又出現(xiàn)了。2009-08-08
postgresql如何找到表中重復(fù)數(shù)據(jù)的行并刪除
這篇文章主要介紹了postgresql如何找到表中重復(fù)數(shù)據(jù)的行并刪除問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
postgresql的now()與Oracle的sysdate區(qū)別說明
這篇文章主要介紹了postgresql的now()與Oracle的sysdate區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
postgresql無序uuid性能測試及對數(shù)據(jù)庫的影響
小編最近在做一個超大表的性能測試,在過程中發(fā)現(xiàn)無序uuid做主鍵對表插入性能有些影響,糾結(jié)該怎么處理這一問題呢?接下來小編給大家分享postgresql無序uuid性能測試的相關(guān)知識幫助大家學(xué)習(xí),需要的彭參考下吧2021-06-06
PostgreSQL對GROUP BY子句使用常量的特殊限制詳解
這篇文章主要介紹了PostgreSQL對GROUP BY子句使用常量的特殊限制詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02

