SQL語句履行次序詳解。本站提示廣大學習愛好者:(SQL語句履行次序詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是SQL語句履行次序詳解正文
本文實例匯總了Oracle完成分頁查詢的SQL語法,整頓給年夜家供年夜家參考之用,概況以下:
1.無ORDER BY排序的寫法。(效力最高)
經由測試,此辦法本錢最低,只嵌套一層,速度最快!即便查詢的數據量再年夜,也簡直不受影響,速度仍然!
sql語句以下:
SELECT * FROM (Select ROWNUM AS ROWNO, T.* from k_task T where Flight_date between to_date('20060501', 'yyyymmdd') and to_date('20060731', 'yyyymmdd') AND ROWNUM <= 20) TABLE_ALIAS WHERE TABLE_ALIAS.ROWNO >= 10;
2.有ORDER BY排序的寫法。(效力最高)
經由測試,此辦法跟著查詢規模的擴展,速度也會愈來愈慢!
sql語句以下:
SELECT * FROM (SELECT TT.*, ROWNUM AS ROWNO FROM (Select t.* from k_task T where flight_date between to_date('20060501', 'yyyymmdd') and to_date('20060531', 'yyyymmdd') ORDER BY FACT_UP_TIME, flight_no) TT WHERE ROWNUM <= 20) TABLE_ALIAS where TABLE_ALIAS.rowno >= 10;
3.無ORDER BY排序的寫法。(建議應用辦法1取代)
此辦法跟著查詢數據量的擴大,速度會愈來愈慢!
sql語句以下:
SELECT * FROM (Select ROWNUM AS ROWNO, T.* from k_task T where Flight_date between to_date('20060501', 'yyyymmdd') and to_date('20060731', 'yyyymmdd')) TABLE_ALIAS WHERE TABLE_ALIAS.ROWNO <= 20 AND TABLE_ALIAS.ROWNO >= 10; TABLE_ALIAS.ROWNO between 10 and 100;
4.有ORDER BY排序的寫法.(建議應用辦法2取代)
此辦法跟著查詢規模的擴展,速度也會愈來愈慢!
sql語句以下:
SELECT * FROM (SELECT TT.*, ROWNUM AS ROWNO FROM (Select * from k_task T where flight_date between to_date('20060501', 'yyyymmdd') and to_date('20060531', 'yyyymmdd') ORDER BY FACT_UP_TIME, flight_no) TT) TABLE_ALIAS where TABLE_ALIAS.rowno BETWEEN 10 AND 20;
5.另類語法。(有ORDER BY寫法)
該語法作風與傳統的SQL語法分歧,不便利浏覽與懂得,為標准與同一尺度,不推舉應用。此處貼出代碼供年夜家參考之用。
sql語句以下:
With partdata as( SELECT ROWNUM AS ROWNO, TT.* FROM (Select * from k_task T where flight_date between to_date('20060501', 'yyyymmdd') and to_date('20060531', 'yyyymmdd') ORDER BY FACT_UP_TIME, flight_no) TT WHERE ROWNUM <= 20) Select * from partdata where rowno >= 10;
6.另類語法 。(無ORDER BY寫法)
With partdata as( Select ROWNUM AS ROWNO, T.* From K_task T where Flight_date between to_date('20060501', 'yyyymmdd') and To_date('20060531', 'yyyymmdd') AND ROWNUM <= 20) Select * from partdata where Rowno >= 10;
信任本文所述代碼可以或許對年夜家有必定的參考自創價值。