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

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

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

最新評(píng)論