小编典典

Oracle SELECT TOP 10 记录

all

我对 Oracle 中的 SQL 语句有一个大问题。我想选择 STORAGE_DB 排序的 TOP 10 记录,这些记录不在其他选择语句的列表中。

这个适用于所有记录:

SELECT DISTINCT 
  APP_ID, 
  NAME, 
  STORAGE_GB, 
  HISTORY_CREATED, 
  TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') AS HISTORY_DATE  
  FROM HISTORY WHERE 
      STORAGE_GB IS NOT NULL AND 
        APP_ID NOT IN (SELECT APP_ID
                       FROM HISTORY
                        WHERE TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') = '06.02.2009')

但是当我添加

AND ROWNUM <= 10
ORDER BY STORAGE_GB DESC

我得到某种“随机”记录。我认为是因为限制发生在订单之前。

有人有好的解决方案吗?另一个问题:这个查询真的很慢(10k+ 条记录)


阅读 73

收藏
2022-08-01

共1个答案

小编典典

您需要将当前查询放在子查询中,如下所示:

SELECT * FROM (
  SELECT DISTINCT 
  APP_ID, 
  NAME, 
  STORAGE_GB, 
  HISTORY_CREATED, 
  TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') AS HISTORY_DATE  
  FROM HISTORY WHERE 
    STORAGE_GB IS NOT NULL AND 
      APP_ID NOT IN (SELECT APP_ID FROM HISTORY WHERE TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') ='06.02.2009')
  ORDER BY STORAGE_GB DESC )
WHERE ROWNUM <= 10

Oracle在返回结果后将rownum应用于结果。
您需要在返回结果后对其进行过滤,因此需要子查询。您还可以使用RANK()函数来获取 Top-N 结果。

为了提高性能,请尝试使用NOT EXISTS代替NOT IN.
有关更多信息,请参阅

2022-08-01