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

2022-03-03 00:00:00 blob select distinct oracle

我尝试在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列之外的所有列分组,按大约两列排序,并为组中的每一行分配行号。结果查询仅检索每个组中的第一行

相关文章