问题
I am new to Postgres XML functions. I have a table as below:
id (VARCHAR) | field1 (text) | attributes (jsonb)
--------------+---------------+----------------------------------
123 | a | {"age": "1", "place": "TX"}
456 | b | {"age": "2", "name": "abcdef"}
789 | |
098 | c | {"name": "gefd"}
Would like to convert it to :
<Company id="123" field="a">
<CompanyTag tagName="age" tagValue="1"/>
<CompanyTag tagName="place" tagValue="TX"/>
</Company>
<Company id="456" field="b">
<CompanyTag tagName="age" tagValue="2"/>
<CompanyTag tagName="name" tagValue="abcdef"/>
</Company>
<Company id="789"/>
<Company id="098" field="c">
<CompanyTag tagName="name" tagValue="gefd"/>
</Company>
Was able to convert the first two column easily using below but the JSONb has the toughest part:
#SELECT xmlelement(name Company, xmlattributes(id as id, field1 as field)) from comp_emp;;
<Company id="123" field="a"/>
<Company id="456" field="b"/>
<Company id="789"/>
<Company id="098" field="c"/>
Please guide me in the right direction.
回答1:
Building on @Georges Martin's solution, I wouldn't use a lateral join and a grouping clause, but rather just a nested subquery:
SELECT XMLELEMENT(
NAME "Company",
XMLATTRIBUTES(id AS id, field1 AS field),
(SELECT XMLAGG(
XMLELEMENT(
NAME "companyTag",
XMLATTRIBUTES(
attr.key AS "tagName",
attr.value AS "tagValue"
)
)
) FROM JSONB_EACH_TEXT(attributes) AS attr)
) FROM comp_emp;
(online demo)
回答2:
This is a partial solution as I forgot the field1
column but this:
SELECT
XMLELEMENT(
NAME "Company",
XMLATTRIBUTES(id AS id),
XMLAGG(
XMLELEMENT(
NAME "CompanyTag",
XMLATTRIBUTES(
(attr).key AS "tagName",
(attr).value AS "tagValue"
)
)
)
)
FROM (
SELECT
id, JSONB_EACH_TEXT(attributes) AS attr
FROM comp_emp
) AS sub
GROUP BY id;
already returns:
<Company id="098">
<CompanyTag tagName="name" tagValue="gefd"/>
</Company>
<Company id="456">
<CompanyTag tagName="age" tagValue="2"/>
<CompanyTag tagName="name" tagValue="abcdef"/>
</Company>
<Company id="123">
<CompanyTag tagName="age" tagValue="1"/>
<CompanyTag tagName="place" tagValue="TX"/>
</Company>
来源:https://stackoverflow.com/questions/64295814/postgres-jsonb-to-xml-with-tag-name-and-tag-value