如何对除BLOB之外的所有字段执行SELECT DISTINCT?

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?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL to Generate Periodic Snapshots from Transactions Table(用于从事务表生成定期快照的SQL)
MyBatis support for multiple databases(MyBatis支持多个数据库)
Oracle 12c SQL: Missing column Headers in result(Oracle 12c SQL:结果中缺少列标题)
SQL query to find the number of customers who shopped for 3 consecutive days in month of January 2020(查询2020年1月连续购物3天的客户数量)
How to get top 10 data weekly (This week, Previous week, Last month, 2 months ago, 3 month ago)(如何每周获取前十大数据(本周、前一周、上个月、2个月前、3个月前))
Select the latest record for an Id per day - Oracle pl sql(选择每天ID的最新记录-Oracle pl SQL)