欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Sql奇技淫巧之ROWNUM偽列的使用

 更新時(shí)間:2023年08月15日 08:14:32   作者:Echoo華地  
本文主要介紹了Sql奇技淫巧之ROWNUM偽列,ROWNUM是一個偽列,它是根據(jù)每次查詢的結(jié)果動態(tài)生成的一列遞增編號,下面就一起來介紹一下如何使用把

ROWNUM偽列

ROWNUM是一個偽列,它是根據(jù)每次查詢的結(jié)果動態(tài)生成的一列遞增編號,表示 Oracle 從表中選擇該行的順序,選擇的第一行ROWNUM為1,第二行ROWNUM為2,以此類推。

注意1:

ROWNUM偽列是在WHERE子句之前生成的,就是說它并不是在執(zhí)行了WHERE子句過濾之后再對數(shù)據(jù)編號
比如在執(zhí)行WHERE子句,結(jié)果數(shù)據(jù)是這樣的:

idnameageROWNUM
0001mary181
0002mike202
0003john193
0004kitty164
0005susy185
0006echoo216

這時(shí)候的ROWNUM是一列遞增排列的、完整的編號
然后如果執(zhí)行一個WHERE子句:WHERE age >18那數(shù)據(jù)就變成了:

idnameageROWNUM
0002mike202
0003john193
0004kitty216

ROWNUM出現(xiàn)了斷層,不連續(xù)了
如果后面再執(zhí)行一個ORDER BY age DESC就變成這樣了:

idnameageROWNUM
0004kitty216
0002mike202
0003john193

ROWNUM不按順序排了
所以在利用ROWNUM偽列來對結(jié)果集做限制、過濾、排序、分頁等操作的時(shí)候一定要注意這個點(diǎn),不然很容易錯亂;

注意2:

ROWNUM是一行一行賦值的,只有上一行數(shù)據(jù)被選擇成功,下一行才會遞增!而且 select 語句也是一行一行選擇的,每 select 一行數(shù)據(jù)就要進(jìn)行 where 條件判斷。
比如有這樣一個employees表:

idnameage
0001mary18
0002mike20
0003john19
0004kitty16
0005susy18
0006echoo21

對這個表執(zhí)行這樣一個SQL:

SELECT * FROM employees WHERE ROWNUM > 1;

這句SQL的預(yù)期為取出除第一條數(shù)據(jù)外的所有數(shù)據(jù),但是執(zhí)行的結(jié)果是一條都選不出來,來看執(zhí)行過程:

① select 出的第一條數(shù)據(jù)為

idnameage
0001mary18

② ROWNUM 給這條數(shù)據(jù)賦值,因?yàn)槭堑谝粭l數(shù)據(jù),所以從 1 開始,賦值完是這樣的:

idnameageROWNUM
0001mary181

③ 進(jìn)行 WHERE ROWNUM > 1 條件判斷,1>1不滿足條件,所以第一條數(shù)據(jù)被過濾掉
④ select 第二條數(shù)據(jù)

idnameage
0002mike20

⑤ ROWNUM 給這條數(shù)據(jù)賦值,因?yàn)樯弦粭l數(shù)據(jù)被過濾掉了,所以還是從 1 開始,賦值完是這樣的:

idnameageROWNUM
0002mike201

⑥ 進(jìn)行 WHERE ROWNUM > 1 條件判斷,1>1不滿足條件,所以這數(shù)據(jù)也被過濾掉
⑦ ·············
一直如此循環(huán)直到結(jié)束,都沒有符合條件的數(shù)據(jù),所以一條數(shù)據(jù)都選不出來!

例1:取前10條數(shù)據(jù)

ROWNUM來限制查詢返回的行數(shù),如下例所示:

SELECT * FROM employees WHERE ROWNUM < 11;

WHERE ROWNUM < 11表示返回查詢數(shù)據(jù)的前10條;

例2:取排序后的前10條數(shù)據(jù)

不能夠像下面這樣直接在WHERE子句后簡單的加上ORDER BY子句了

SELECT * FROM employees WHERE ROWNUM < 11 ORDER BY age;

因?yàn)檫@里的意思是先執(zhí)行WHERE子句選出ROWNUM1~10的數(shù)據(jù),然后再進(jìn)行排列,和我們預(yù)想不符。我們要的是按年齡排序后的前10條數(shù)據(jù)。
所以應(yīng)該這樣寫:

SELECT *
  FROM (SELECT * FROM employees ORDER BY employee_id)
  WHERE ROWNUM < 11;

這里的意思就是先執(zhí)行排序,然后對排完序的結(jié)果集用ROWNUM偽列按順序編號,然后取其中ROWNUM為1~10的那10條數(shù)據(jù);

例3:分頁

SELECT * 
FROM( SELECT temp_table.*,ROWNUM AS rn
  	  FROM (SELECT * FROM employees ORDER BY employee_id) temp_table
  	 ) result_table
WHERE result_table.rn BETWEEN 起始行數(shù) AND 結(jié)尾行數(shù)

通過嵌套查詢的方式,把動態(tài)的ROWNUM偽列變成固定的列rn,然后再用rn列進(jìn)行分頁;

到此這篇關(guān)于Sql奇技淫巧之ROWNUM偽列的文章就介紹到這了,更多相關(guān)Sql奇技淫巧之ROWNUM偽列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論