我想使用 rownumber() 从 oracle 获取最后一条记录

I want to get the last record from oracle using rownumber()

这里正在使用 oracle 查询以下记录,我想要最后行号 11 的记录。

     select max(t.atdatetime),
     t.lead,
     t.sysid,
     row_number() over(partition by t.sysid order by t.lead desc) as "number" from psd.psd_empreport t where t.sysid in(5350) group by t.lead, t.sysid   order by 2 desc

        SNO   datetime              tlcode  ecode  rownumb

         1  7/2/2013 6:00:25 AM      67    5350     1
         2  10/27/2014 8:30:34 AM   5508    5350    2
         3  10/24/2014 8:30:21 AM   5477    5350    3
         4  9/22/2012 12:28:20 AM   5051    5350    4
         5  10/10/2012 12:28:47 AM  4736    5350    5
         6  5/13/2014 8:24:21 AM    4459    5350    6
         7  9/12/2012 12:28:01 AM   3688    5350    7
         8  2/7/2013 12:32:34 AM    227     5350    8
         9  3/27/2013 12:34:39 AM   140     5350    9
        10  3/1/2013 12:33:27 AM    13      5350    10
        11  9/9/2014 8:28:41 AM     122     5350    11

i want to last rownumber 11 record.

您只需要 ORDER BY DESCROW_NUMBER() window 然后 select 具有 row_number 作为来自 子查询 .

的 1

例如,

SQL> SELECT *
  2  FROM
  3    ( SELECT empno, row_number() OVER(ORDER BY empno DESC) rn FROM emp
  4    )
  5  WHERE rn = 1;

     EMPNO         RN
---------- ----------
      7934          1

因此,将您现有的查询设为 子查询过滤器 row_number 作为 where rn = 1