PostgreSQL:string_agg?多列值聚合成一列的操作示例
PostgreSQL:string_agg 多列值聚合成一列
string_agg
是PostgreSQL中的一個(gè)聚合函數(shù),用于將一組值連接為一個(gè)字符串。它接受兩個(gè)參數(shù):要連接的值和連接符。
語(yǔ)法如下:
string_agg(expression, delimiter)
其中,expression
是要連接的值的表達(dá)式,可以是列名、常量或表達(dá)式;delimiter
是用于分隔連接的字符串。
string_agg
通常結(jié)合GROUP BY
子句一起使用,以便將結(jié)果按組連接到一列中。
下面是一個(gè)示例:
SELECT string_agg(name, ', ') AS concatenated_names FROM employee;
該查詢將連接employee
表中所有員工的姓名,并使用逗號(hào)分隔。結(jié)果將在一列中顯示。
請(qǐng)注意,使用string_agg
函數(shù)時(shí),要注意連接后的字符串可能會(huì)超過(guò)數(shù)據(jù)庫(kù)中設(shè)置的字符串長(zhǎng)度限制。如果需要,可以使用substring
函數(shù)截?cái)嘟Y(jié)果字符串以滿足長(zhǎng)度要求。
示例
create table employee( id int4 primary key, name varchar(100) ); comment on table employee is '職工表'; comment on column employee.name is '職工名'; insert into employee(id,name) values (1,'張三'); insert into employee(id,name) values (2,'李四'); insert into employee(id,name) values (3,'王二'); insert into employee(id,name) values (4,'麻子'); select string_agg(name,', ') as concatenated_names from employee;
結(jié)果 張三, 李四, 王二, 麻子
postgresql 系列之聚合函數(shù)string_agg 和 array_agg
本文是《postgresql實(shí)戰(zhàn)》的讀書(shū)筆記;具體可以參考這本書(shū)相關(guān)章節(jié)。
一、 string_agg 函數(shù)
語(yǔ)法格式如下:
string_agg(expression,delimiter)
string_agg
函數(shù)能將結(jié)果集某個(gè)字段的所有行連接成字符串,并以delimiter
分隔符分隔,expression
表示要處理的字符類(lèi)型數(shù)據(jù);
案例:
CREATE TABLE city( country character varying(64), city character varying(64) ); INSERT INTO city VALUES ('中國(guó)','臺(tái)北'), ('中國(guó)','香港'), ('中國(guó)','上海'), ('日本','東京'), ('日本','大阪');
SELECT country,string_agg(city,',') FROM city GROUP BY country;
二、array_agg 函數(shù)
array_agg
函數(shù) 和string_agg
函數(shù)類(lèi)似,最主要的區(qū)別為返回的類(lèi)型為數(shù)組,數(shù)組數(shù)據(jù)類(lèi)型同輸入數(shù)據(jù)類(lèi)型一致,array_agg
函數(shù)支持兩種語(yǔ)法。
array_agg(expression) --輸入?yún)?shù)為任何非數(shù)組類(lèi)型
array_agg
函數(shù)輸出的結(jié)果為字符類(lèi)型數(shù)組,使用array_agg
函數(shù)主要優(yōu)點(diǎn)在于可以使用數(shù)組相關(guān)函數(shù)和操作符。
案例:
-- 創(chuàng)建數(shù)組 create table test_array(id int4[]); INSERT INTO test_array(id) values(array[1,2,4]),(array[4,5,6]);
可以將array_agg
函數(shù)輸出類(lèi)型轉(zhuǎn)成字符串,并用指定分隔符分隔
補(bǔ)充
-- string_to_array 將字符串轉(zhuǎn)成數(shù)字,通過(guò)自定切割符合。 select array_length(string_to_array('1.2.3.4.5','.'), 1); --5 --array_length(anyarray,int) 返回?cái)?shù)組指定維度的長(zhǎng)度
參考
《postgresql實(shí)戰(zhàn)》
到此這篇關(guān)于PostgreSQL:string_agg多列值聚合成一列的文章就介紹到這了,更多相關(guān)PostgreSQL多列值聚合成一列內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PostgreSQL數(shù)據(jù)庫(kù)中如何保證LIKE語(yǔ)句的效率(推薦)
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫(kù)中如何保證LIKE語(yǔ)句的效率,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03使用postgresql 模擬批量數(shù)據(jù)插入的案例
這篇文章主要介紹了使用postgresql 模擬批量數(shù)據(jù)插入的案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01Postgresql排序與limit組合場(chǎng)景性能極限優(yōu)化詳解
這篇文章主要介紹了Postgresql排序與limit組合場(chǎng)景性能極限優(yōu)化詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12PostgreSQL?16?新特性之正態(tài)分布隨機(jī)數(shù)函數(shù)的示例
這篇文章主要介紹了PostgreSQL?16?新特性之正態(tài)分布隨機(jī)數(shù)函數(shù),PostgreSQL 16 新增了一個(gè)內(nèi)置的 random_normal() 函數(shù),用于生成這種隨機(jī)數(shù),通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01PostgreSQL更新表時(shí)時(shí)間戳不會(huì)自動(dòng)更新的解決方法
這篇文章主要為大家詳細(xì)介紹了PostgreSQL更新表時(shí)時(shí)間戳不會(huì)自動(dòng)更新的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10PostgreSQL拼接字符串的幾種方法簡(jiǎn)單示例
在PostgreSQL中有多種方式可以拼接字符串,這篇文章主要給大家介紹了關(guān)于PostgreSQL拼接字符串的幾種方法,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01CVE-2019-9193之PostgreSQL?任意命令執(zhí)行漏洞的問(wèn)題
這篇文章主要介紹了CVE-2019-9193:PostgreSQL?任意命令執(zhí)行漏洞,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08