How can I perform a SELECT DISTINCT on all fields except a BLOB?(如何对除BLOB之外的所有字段执行SELECT DISTINCT?)
本文介绍了如何对除BLOB之外的所有字段执行SELECT DISTINCT?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我尝试在Oracle中执行SELECT DISTINCT查询,如下所示:
SELECT
MOVIES.TITLE, CERTIFICATIONS.ID, PROJECTION.DAY, TIME_SLOTS.SLOT,
PROJECTION.REMAINING_SEATS, IMAGES.IMAGE
FROM
[...]
它不起作用,因为列";IMAGES.IMAGE&qot;是一个BLOB。我想将这个字段从不同的字段中排除(因为我不需要它是唯一的),而且我不知道如何做到这一点。我还尝试使用GROUP BY子句,但如果尝试对除BLOB之外的所有字段进行分组,Oracle将返回以下错误:
ORA-00979:不是GROUP BY表达式
如果我将该字段添加到GROUP BY子句中,Oracle将返回以下内容:
ORA-00932:数据类型不一致:预期获得的Blob
我能做些什么?
推荐答案
SELECT DISTINCT MOVIES.TITLE, CERTIFICATIONS.ID, PROJECTION.DAY, TIME_SLOTS.SLOT, PROJECTION.REMAINING_SEATS
FROM [...]
DISTINCT将应用于选择列表中的所有列。是的,您不能在GROUP BY、UNION、DISTINCT等中使用LOB,因为Oracle不知道如何比较不同的LOB
如果您还想检索BLOB,可以尝试如下操作:
SELECT MOVIES.TITLE, CERTIFICATIONS.ID,
PROJECTION.DAY, TIME_SLOTS.SLOT, PROJECTION.REMAINING_SEATS, IMAGES.IMAGE
FROM (
SELECT MOVIES.TITLE, CERTIFICATIONS.ID,
PROJECTION.DAY, TIME_SLOTS.SLOT, PROJECTION.REMAINING_SEATS, IMAGES.IMAGE,
row_number() over (partition by MOVIES.TITLE, CERTIFICATIONS.ID, PROJECTION.DAY, TIME_SLOTS.SLOT, PROJECTION.REMAINING_SEATS
order by PROJECTION.DAY, TIME_SLOTS.SLOT) RW
FROM [...]
) WHERE RW = 1;
但您应该了解您在寻找什么。例如,上面的查询将除BLOB列之外的所有列分组,按大约两列排序,并为组中的每一行分配行号。结果查询仅检索每个组中的第一行
这篇关于如何对除BLOB之外的所有字段执行SELECT DISTINCT?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何对除BLOB之外的所有字段执行SELECT DISTINCT?
基础教程推荐
猜你喜欢
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- 带更新的 sqlite CTE 2022-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
