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选择动态行值作为列名,另一列作为值 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- oracle区分大小写的原因? 2021-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- 在多列上分布任意行 2021-01-01