可用版本:Dev (3.21) | 最新 (3.20) | 3.19 | 3.18 | 3.17 | 3.16 | 3.15 | 3.14

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

反馈

您对此页面有任何反馈吗? 我们很乐意听取您的意见!

The jOOQ Logo