如何解决groupby在oracle sql中检查其每个日期
我有一个表ISIN_TBL
,其中有两个字段IDENTIFIER
和ALLT_DATE
,它们的数据类型分别为varchar
和Date
。
表中的每个ALLT_DATE
有很多IDENTIFIER
。通常,对于每个IDENTIFIER
,ALLT_DATE
应该相同。但是只是为了确认我想写一个SQL查询来列出具有不同IDENTIFIER
的列表ALLT_DATE
。
我想修改下面的SQL查询:
Select count(*),IDENTIFIER,ALLT_DATE
from ISIN_TBL
group by IDENTIFIER,ALLT_DATE
解决方法
您可以使用GROUP BY
和HAVING
来获得例外情况
Select IDENTIFIER
from ISIN_TBL
group by IDENTIFIER
having MIN(ALLT_DATE) <> MAX(ALLT_DATE);
如果您想要日期列表-并且时间不太长-您可以使用LISTAGG()
:
Select IDENTIFIER,LISTAGG(ALLT_DATE,',') WITHIN GROUP (ORDER BY ALLT_DATE)
from ISIN_TBL
group by IDENTIFIER
having MIN(ALLT_DATE) <> MAX(ALLT_DATE);
或者如果有很多行,请使用SELECT DISTINCT
来获得不同的值:
Select IDENTIFIER,') WITHIN GROUP (ORDER BY ALLT_DATE)
from (SELECT DISTINCT IDENTIFIER,ALLT_DATE
FROM ISIN_TBL
) t
group by IDENTIFIER
having MIN(ALLT_DATE) <> MAX(ALLT_DATE);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。