PostgreSQL:string_agg?多列值聚合成一列的操作示例
PostgreSQL:string_agg 多列值聚合成一列
string_agg是PostgreSQL中的一個聚合函數(shù),用于將一組值連接為一個字符串。它接受兩個參數(shù):要連接的值和連接符。
語法如下:
string_agg(expression, delimiter)
其中,expression是要連接的值的表達式,可以是列名、常量或表達式;delimiter是用于分隔連接的字符串。
string_agg通常結合GROUP BY子句一起使用,以便將結果按組連接到一列中。
下面是一個示例:
SELECT string_agg(name, ', ') AS concatenated_names FROM employee;
該查詢將連接employee表中所有員工的姓名,并使用逗號分隔。結果將在一列中顯示。
請注意,使用string_agg函數(shù)時,要注意連接后的字符串可能會超過數(shù)據(jù)庫中設置的字符串長度限制。如果需要,可以使用substring函數(shù)截斷結果字符串以滿足長度要求。
示例
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;結果 張三, 李四, 王二, 麻子
postgresql 系列之聚合函數(shù)string_agg 和 array_agg
本文是《postgresql實戰(zhàn)》的讀書筆記;具體可以參考這本書相關章節(jié)。
一、 string_agg 函數(shù)
語法格式如下:
string_agg(expression,delimiter)
string_agg 函數(shù)能將結果集某個字段的所有行連接成字符串,并以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ù)輸出的結果為字符類型數(shù)組,使用array_agg函數(shù)主要優(yōu)點在于可以使用數(shù)組相關函數(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ù)輸出類型轉成字符串,并用指定分隔符分隔

補充
-- string_to_array 將字符串轉成數(shù)字,通過自定切割符合。
select array_length(string_to_array('1.2.3.4.5','.'), 1); --5
--array_length(anyarray,int) 返回數(shù)組指定維度的長度參考
《postgresql實戰(zhàn)》
到此這篇關于PostgreSQL:string_agg多列值聚合成一列的文章就介紹到這了,更多相關PostgreSQL多列值聚合成一列內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率(推薦)
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
使用postgresql 模擬批量數(shù)據(jù)插入的案例
這篇文章主要介紹了使用postgresql 模擬批量數(shù)據(jù)插入的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
Postgresql排序與limit組合場景性能極限優(yōu)化詳解
這篇文章主要介紹了Postgresql排序與limit組合場景性能極限優(yōu)化詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
PostgreSQL?16?新特性之正態(tài)分布隨機數(shù)函數(shù)的示例
這篇文章主要介紹了PostgreSQL?16?新特性之正態(tài)分布隨機數(shù)函數(shù),PostgreSQL 16 新增了一個內置的 random_normal() 函數(shù),用于生成這種隨機數(shù),通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-01-01
CVE-2019-9193之PostgreSQL?任意命令執(zhí)行漏洞的問題
這篇文章主要介紹了CVE-2019-9193:PostgreSQL?任意命令執(zhí)行漏洞,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08

