sql >> Databasteknik >  >> RDS >> PostgreSQL

XML-elementnamn från data i Postgres

Det är inte möjligt att använda någon SQL/XML-funktion med dynamiskt taggnamn. Du kan använda ett format funktion.

postgres=# SELECT * FROM foo;
┌──────┬──────┐
│  nm  │ val  │
╞══════╪══════╡
│ buy  │  100 │
│ sell │ 1000 │
│ buy  │  102 │
│ sell │ 1033 │
└──────┴──────┘
(4 rows)

postgres=# SELECT xmlelement(name "trades", xmlagg(x)) 
              FROM (SELECT format('<%1$s>%2$s</%1$s>', 
                                   nm, 
                                   xmlagg(xmlelement(name value, val)))::xml x 
                        FROM foo group by nm) s;
┌─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┐
│                                                    xmlelement                                                       │
╞═════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╡
│ <trades><sell><value>1000</value><value>1033</value></sell><buy><value>100</value><value>102</value></buy></trades> │
└─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘
(1 row)



  1. SUM() fungerar inte i MySQL :SUM() med DISTINCT

  2. Hur man konverterar en sträng till en tidsstämpel i PostgreSQL

  3. MySQL välj rader där left join är null

  4. Hur man lägger till en till sträng i oracle