子查詢中不能包含order by

博客轉自:http://blog.csdn.net/cynhafa/article/details/8183083


===================================博客原文======

今天做開發遇到一個問題:寫sql語句:

select  top 20 * from (select top 200 * from ump_user order by id)ttnn 

sql查不出來   因爲子查詢中不能包含order by 子句


具體原因:
在8i以前,子查詢中不能包含Order By子句。

從8i開始,子查詢可以有Order By,但必須是有top-n的這種子查詢時才能用。

所謂的top-N查詢就是:
TOP-N一般是指最大的n條記錄或着是最小的n條記錄。
如:
    select rownum , t.col1, t.col2, ... from  
    ( select col1, col2, ... from tab  
      order by col1 ) t  
    where rownum <= n;  

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章