首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLAnywhere 16中的聚合结果(用于XML替换)

SQLAnywhere 16中的聚合结果(用于XML替换)
EN

Stack Overflow用户
提问于 2022-07-10 23:36:16
回答 1查看 10关注 0票数 0

我使用Ultralite 16.0,并试图将多个行聚合为一个行。

我有一个电影表和一个类型表,通过film_genre表有很多到多个关系。

我想要这样的结果:

代码语言:javascript
复制
| mFilm     | idGenre |
| --------- | ------- |
| Film_One  | 1, 2    |
| Film_Two  | 1, 3, 4 |

我可以在(SSMS)中轻松地使用

代码语言:javascript
复制
SELECT f.nmFilm, 
(
  REPLACE(
      STUFF(
          (SELECT g.idGenre FROM genre g
              JOIN film_genre fg on g.idGenre = fg.idGenre
              WHERE fg.idFilm = f.idFilm
              FOR XML PATH('')
          ) , 1 , 1 , ''
      )
  , '&', '&')
) AS genres FROM film f;

但是,每当我试图在SQLAnywhere中使用FOR时,如下面的查询中所示

代码语言:javascript
复制
SELECT f.nmFilm, 
    (SELECT g.idGenre FROM genre g
      JOIN film_genre fg on g.idGenre = fg.idGenre
      WHERE fg.idFilm = f.idFilm
      FOR XML AUTO
    ) AS genres FROM film f;

我得到语法错误

无法执行语句。“XML”SQL偏移量附近的UltraLite数据库语法错误: 57 SQLCODE=-131,ODBC 3 State="42000“行,第1列

我在文档中找不到对XML的任何引用,所以我不确定这在16.0版中是否可用。

我怎样才能做到这一点?

EN

回答 1

Stack Overflow用户

发布于 2022-07-10 23:36:16

如果其他人需要这样做,我所要做的就是使用LIST()函数。

代码语言:javascript
复制
SELECT f.nmFilm, 
  (SELECT LIST(g.idGenre) FROM genre g
    JOIN film_genre fg on g.idGenre = fg.idGenre
    WHERE fg.idFilm = f.idFilm
  ) AS genres
FROM film f;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72932553

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档