欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PostgreSQL:string_agg?多列值聚合成一列的操作示例

 更新時間:2023年08月05日 09:08:36   作者:qq_35987023  
PostgreSQL中的STRING_AGG()函數(shù)是一個聚合函數(shù),用于連接字符串列表并在字符串之間放置分隔符,這篇文章主要介紹了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)文章

最新評論