加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 如何在Oracle的CLOB列上使用GROUP BY?

发布时间:2020-12-12 07:46:08 所属栏目:MsSql教程 来源:网络整理
导读:我正在尝试将GROUP BY函数与oracle中的MAX结合起来.我阅读了很多文档,试着弄清楚如何格式化我的请求,Oracle总是返回: ORA-00979: “not a group by expression” 这是我的要求: SELECT A.T_ID,B.T,MAX(A.V) FROM bdd.LOG A,bdd.T_B BWHERE B.T_ID = A.T_IDG
我正在尝试将GROUP BY函数与oracle中的MAX结合起来.我阅读了很多文档,试着弄清楚如何格式化我的请求,Oracle总是返回:

ORA-00979: “not a group by expression”

这是我的要求:

SELECT A.T_ID,B.T,MAX(A.V) 
FROM bdd.LOG A,bdd.T_B B
WHERE B.T_ID = A.T_ID
GROUP BY A.T_ID
HAVING MAX(A.V) < '1.00';

有小费吗 ?

编辑它似乎有一些棘手的部分我的字段的数据类型.

> T_ID是VARCHAR2
> A.V是VARCHAR2
> B.T是CLOB

解决方法

我非常熟悉为其他人设计的表格编写查询的现象,这些表格几乎完全不同于你想要的东西.当我遇到同样的问题时,我已经习惯了.
GROUP BY TO_CHAR(theclob)

然后你当然也必须在输出中删除clo_CHAR.

请注意,这个问题有2个级别……首先是你有一个不需要clob的clob列;它只包含一些适合VARCHAR2的小字符串.我的解决方法适用于此.

第二级是您实际上想要按包含大字符串的列进行分组.在这种情况下,TO_CHAR可能无济于事.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读