微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在分组依据中使用案例陈述列

如何解决如何在分组依据中使用案例陈述列

别名不能在GROUP BY中使用,因为GROUP BY发生时,别名尚未定义:

Here's the order:
1.FROM
2.WHERE
3.GROUP BY
4.HAVING
5.SELECT
6.ORDER BY

您可以使用以下方法解决此问题:

SELECT column1,column2,case_column
FROM (
SELECT SOME_TABLE_ALIAS.COLUMN1, OTHER_TABLE_ALIAS.COLUMN2,
CASE
    WHEN SOME_TABLE_ALIAS.COLUMN3 IS NOT NULL THEN 'A'
    ELSE 'B'
END AS CASE_COLUMN
FROM SOME_TABLE SOME_TABLE_ALIAS
... (other table joins and where clauses)
) a
GROUP BY COLUMN1, COLUMN2, CASE_COLUMN

或者只使用您在GROUP BY中的SELECT中使用的情况

解决方法

如该问题所述,我试图制定一个查询,该查询在列结果中包含一个case语句,然后我想将该列包含在查询的group
by语句中。举一个具体的例子,这几乎是我查询的样子:

SELECT SOME_TABLE_ALIAS.COLUMN1,OTHER_TABLE_ALIAS.COLUMN2,CASE
    WHEN SOME_TABLE_ALIAS.COLUMN3 IS NOT NULL THEN 'A'
    ELSE 'B'
END AS CASE_COLUMN
FROM SOME_TABLE SOME_TABLE_ALIAS
... (other table joins and where clauses)
GROUP BY SOME_TABLE_ALIAS.COLUMN1,CASE_COLUMN

在来到这里之前,我检查了一些网站,包括网站,以尝试解决我的问题。我尝试CASE在链接的网页中显示“
like”之后添加另一个别名,但是没有运气。我继续收到的错误消息如下:

[Error] Script lines: 127-151 ----------------------
 CASE_COLUMN IS NOT VALID IN THE CONTEXT WHERE IT IS USED. SQLCODE=-206,SQLSTATE=42703,DRIVER=3.53.71

是否还有其他人遇到我所面临的问题,并且能够GROUP BYCASE声明的结果上使用?任何帮助,将不胜感激。哦,DB2版本是z /
OS实例,版本10(DSN10015)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。