oracle: Rownum原理

來源:互聯網
上載者:User

標籤:

Rownum原理:

1 Oracle executes your query.

執行查詢操作

2 Oracle fetches the first row and calls it row number 1.

將第一行的row num置為1

3 Have we gotten past row number meets the criteria? If no, then Oracle discards the row, If yes, then Oracle return the row.

將得到的行的row num與條件相比較,如果不匹配,則拋棄行,如果匹配,則返回行

4 Oracle fetches the next row and advances the row number (to 2, and then to 3, and then to 4, and so forth).

oracle擷取下一行,然後將rownum增1

5 Go to step 3.

返回第3步

 

從這個原理可以知道,select rownum,name from emp where rownum>5;不返回行,因為首先執行查詢select name from emp,將第1行的rownum標為1,然後看where條件,為false,則拋棄行,執行第2行,還是rownum標為1,看where條件還為false,所以永遠是false,rownum不改變,所有的行都被拋棄,所以沒有結果。

where rownum = n(n>1)

where rownum > n 都不可用,也就是上面的原因

oracle: Rownum原理

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.