取得某列中第N大的行 select column_name from (select table_name.*,dense_rank() over (order by column desc) rank from table_name) where rank = &N;
假如要返回前5条记录: select * from tablename where rownum<6;(或是rownum <= 5 或是rownum != 6) 假如要返回第5-9条记录: select * from tablename where … and rownum<10 minus select * from tablename where … and rownum<5 order by name 选出结果后用name排序显示结果。(先选再排序)
注意:只能用以上符号(<、<=、!=)。 select * from tablename where rownum != 10;返回的是前9条记录。 不能用:>;,>;=,=,Between...and。由于rownum是一个总是从1开始的伪列,Oracle 认为这种条件 不成立,查不到记录.
|