PostgreSQL:string_agg?多列值聚合成一列的操作示例
PostgreSQL:string_agg 多列值聚合成一列
string_agg
是PostgreSQL中的一個聚合函數(shù),用于將一組值連接為一個字符串。它接受兩個參數(shù):要連接的值和連接符。
語法如下:
string_agg(expression, delimiter)
其中,expression
是要連接的值的表達式,可以是列名、常量或表達式;delimiter
是用于分隔連接的字符串。
string_agg
通常結(jié)合GROUP BY
子句一起使用,以便將結(jié)果按組連接到一列中。
下面是一個示例:
SELECT string_agg(name, ', ') AS concatenated_names FROM employee;
該查詢將連接employee
表中所有員工的姓名,并使用逗號分隔。結(jié)果將在一列中顯示。
請注意,使用string_agg
函數(shù)時,要注意連接后的字符串可能會超過數(shù)據(jù)庫中設(shè)置的字符串長度限制。如果需要,可以使用substring
函數(shù)截斷結(jié)果字符串以滿足長度要求。
示例
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實戰(zhàn)》的讀書筆記;具體可以參考這本書相關(guān)章節(jié)。
一、 string_agg 函數(shù)
語法格式如下:
string_agg(expression,delimiter)
string_agg
函數(shù)能將結(jié)果集某個字段的所有行連接成字符串,并以delimiter
分隔符分隔,expression
表示要處理的字符類型數(shù)據(jù);
案例:
CREATE TABLE city( country character varying(64), city character varying(64) ); INSERT INTO city VALUES ('中國','臺北'), ('中國','香港'), ('中國','上海'), ('日本','東京'), ('日本','大阪');
SELECT country,string_agg(city,',') FROM city GROUP BY country;
二、array_agg 函數(shù)
array_agg
函數(shù) 和string_agg
函數(shù)類似,最主要的區(qū)別為返回的類型為數(shù)組,數(shù)組數(shù)據(jù)類型同輸入數(shù)據(jù)類型一致,array_agg
函數(shù)支持兩種語法。
array_agg(expression) --輸入?yún)?shù)為任何非數(shù)組類型
array_agg
函數(shù)輸出的結(jié)果為字符類型數(shù)組,使用array_agg
函數(shù)主要優(yōu)點在于可以使用數(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ù)輸出類型轉(zhuǎn)成字符串,并用指定分隔符分隔
補充
-- string_to_array 將字符串轉(zhuǎn)成數(shù)字,通過自定切割符合。 select array_length(string_to_array('1.2.3.4.5','.'), 1); --5 --array_length(anyarray,int) 返回數(shù)組指定維度的長度
參考
《postgresql實戰(zhàn)》
到此這篇關(guān)于PostgreSQL:string_agg多列值聚合成一列的文章就介紹到這了,更多相關(guān)PostgreSQL多列值聚合成一列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率(推薦)
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03使用postgresql 模擬批量數(shù)據(jù)插入的案例
這篇文章主要介紹了使用postgresql 模擬批量數(shù)據(jù)插入的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01Postgresql排序與limit組合場景性能極限優(yōu)化詳解
這篇文章主要介紹了Postgresql排序與limit組合場景性能極限優(yōu)化詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12PostgreSQL?16?新特性之正態(tài)分布隨機數(shù)函數(shù)的示例
這篇文章主要介紹了PostgreSQL?16?新特性之正態(tài)分布隨機數(shù)函數(shù),PostgreSQL 16 新增了一個內(nèi)置的 random_normal() 函數(shù),用于生成這種隨機數(shù),通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-01-01CVE-2019-9193之PostgreSQL?任意命令執(zhí)行漏洞的問題
這篇文章主要介紹了CVE-2019-9193:PostgreSQL?任意命令執(zhí)行漏洞,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08