PostgreSQL 行列轉(zhuǎn)換的實現(xiàn)方法
一、造測試數(shù)據(jù)
create table test (
id int,
json1 varchar,
json2 varchar
);
insert into test values(1,'111','{111}');
insert into test values(2,'111,222','{111,222}');
insert into test values(3,'111,222,333','{111,222,333}');
select * from test;造完數(shù)據(jù)如下

二、行轉(zhuǎn)列
1.函數(shù)定義
regexp_split_to_table是PostgreSQL中的一個函數(shù),用于將一個字符串根據(jù)正則表達式進行分割,并將結(jié)果返回為一個表格,每個分割后的部分作為一行。
2.語法
regexp_split_to_table(string text, pattern text) → setof text string:要分割的原始字符串。 pattern:用于分割的正則表達式模式? 返回值,該函數(shù)返回一個setof text,即一個文本類型的行集合,包含所有分割后的部分
3.示例
select
id
,json1
,json2
,regexp_replace(regexp_replace(json2,'{',''),'}','') no_json2 --剔除json2外面大括號
,regexp_split_to_table(json1,',') as j1 --使用json1來轉(zhuǎn)換結(jié)果
,regexp_split_to_table(regexp_replace(regexp_replace(json2,'{',''),'}',''),',') as j2 --使用json2來轉(zhuǎn)換結(jié)果
from test
;執(zhí)行結(jié)果

三、列轉(zhuǎn)行
1.函數(shù)定義
string_agg() 函數(shù)是 PostgreSQL 中的一個聚合函數(shù),用于將一個列中的值連接成一個字符串。
2.語法
string_agg(column_name, separator) column_name:要聚合的列名。 separator:可選參數(shù),用于連接各個值的分隔符。如果未指定或為空,則使用默認分隔符(逗號加空格)。
3.示例
--將j1用;拼接
select string_agg (j1,';')
from (
select
id
,json1
,json2
,regexp_replace(regexp_replace(json2,'{',''),'}','') no_json2 --剔除json2外面大括號
,regexp_split_to_table(json1,',') as j1 --使用json1來轉(zhuǎn)換結(jié)果
,regexp_split_to_table(regexp_replace(regexp_replace(json2,'{',''),'}',''),',') as j2 --使用json2來轉(zhuǎn)換結(jié)果
from test
) t
;執(zhí)行結(jié)果

--根據(jù)id分組按j1用abc拼接
select id,string_agg (j1,'abc')
from (
select
id
,json1
,json2
,regexp_replace(regexp_replace(json2,'{',''),'}','') no_json2 --剔除json2外面大括號
,regexp_split_to_table(json1,',') as j1 --使用json1來轉(zhuǎn)換結(jié)果
,regexp_split_to_table(regexp_replace(regexp_replace(json2,'{',''),'}',''),',') as j2 --使用json2來轉(zhuǎn)換結(jié)果
from test
) t
group by id
;執(zhí)行結(jié)果

到此這篇關于pgsql行列轉(zhuǎn)換的實現(xiàn)方法的文章就介紹到這了,更多相關pgsql行列轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
PostgreSQL數(shù)據(jù)庫命令行執(zhí)行SQL腳本的三種方式
生成環(huán)境中,出于安全性等原因,往往不提供數(shù)據(jù)庫連接工具,所以對數(shù)據(jù)庫的更新和升級就得通過命令行來實現(xiàn),本文總結(jié)了三種命令行執(zhí)行sql腳本的方式,需要的朋友可以參考下2024-02-02
Postgresql數(shù)據(jù)庫之創(chuàng)建和修改序列的操作
這篇文章主要介紹了Postgresql數(shù)據(jù)庫之創(chuàng)建和修改序列的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
PGSQL 實現(xiàn)把字符串轉(zhuǎn)換成double類型(to_number())
這篇文章主要介紹了PGSQL 實現(xiàn)把字符串轉(zhuǎn)換成double類型(to_number()),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
PostgreSQL字符切割:substring函數(shù)的用法說明
這篇文章主要介紹了PostgreSQL字符切割:substring函數(shù)的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
Postgresql 查看SQL語句執(zhí)行效率的操作
這篇文章主要介紹了Postgresql 查看SQL語句執(zhí)行效率的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
自定義函數(shù)實現(xiàn)單詞排序并運用于PostgreSQL(實現(xiàn)代碼)
這篇文章主要介紹了自定義函數(shù)實現(xiàn)單詞排序并運用于PostgreSQL,本文給大家分享實現(xiàn)代碼,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
postgresql行轉(zhuǎn)列與列轉(zhuǎn)行圖文教程
PostgreSQL是一種開源的關系型數(shù)據(jù)庫,它提供了多種管理工具來操作數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關于postgresql行轉(zhuǎn)列與列轉(zhuǎn)行的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-06-06
pg中replace和translate的用法說明(數(shù)據(jù)少的中文排序)
這篇文章主要介紹了pg中replace和translate的用法說明(數(shù)據(jù)少的中文排序),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

