XMLAGG
适用于 ✅ 开源版 ✅ 专业版 ✅ 企业版
可以使用 XMLAGG
将数据集聚合为 org.jooq.XML
元素
SELECT xmlelement( NAME ids, xmlagg(xmlelement(NAME id, id)) ) FROM author
create.select(xmlelement("ids", xmlagg(xmlelement("id", AUTHOR.ID)) )) .from(AUTHOR) .fetch();
结果如下
+---------------------------------+ | xmlelement | +---------------------------------+ | <ids><id>1</id><id>2</id></ids> | +---------------------------------+
排序聚合内容
将数据聚合到 XML 中时,排序可能很重要。为此,请在 XMLAGG
中使用 ORDER BY
子句
SELECT xmlelement( NAME ids, xmlagg(xmlelement(NAME id, id) ORDER BY id DESC) ) FROM author
create.select(xmlelement("ids", xmlagg(xmlelement("id", AUTHOR.ID)) .orderBy(AUTHOR.ID.desc()))) .from(AUTHOR) .fetch();
结果如下
+---------------------------------+ | xmlelement | +---------------------------------+ | <ids><id>2</id><id>1</id></ids> | +---------------------------------+
方言支持
此示例使用 jOOQ
xmlagg(xmlelement("id", AUTHOR.ID))
翻译成以下特定方言的表达式
DB2、Oracle、Postgres、Teradata
xmlagg(xmlelement(NAME id, AUTHOR.ID))
ASE、Access、Aurora MySQL、Aurora Postgres、BigQuery、ClickHouse、CockroachDB、Databricks、Derby、DuckDB、Exasol、Firebird、H2、HSQLDB、Hana、Informix、MariaDB、MemSQL、MySQL、Redshift、SQLDataWarehouse、SQLServer、SQLite、Snowflake、Sybase、Trino、Vertica、YugabyteDB
/* UNSUPPORTED */
使用 jOOQ 3.21 生成。早期 jOOQ 版本的支持可能有所不同。 在我们的网站上翻译您自己的 SQL
反馈
您对此页面有任何反馈吗? 我们很乐意听取您的意见!