自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle查詢前10條記錄的操作方案

數(shù)據(jù)庫(kù) Oracle
本文主要是通過(guò)介紹Oracle查詢前10條記錄的相關(guān)實(shí)際應(yīng)用代碼來(lái)引出Oracle查詢前10條記錄的實(shí)際操作,以下就是文章的詳細(xì)介紹。

如果你想了解Oracle查詢前10條記錄的相關(guān)實(shí)際應(yīng)用方案的話,你就可以點(diǎn)擊以下的文章對(duì)其在實(shí)際相關(guān)操作中的正確用法,有一個(gè)更加完善的認(rèn)識(shí),希望你在瀏覽完以下的文章會(huì)以下就是正文的詳細(xì)內(nèi)容的介紹。

在Oracle怎樣查詢表中的top10條記錄呢?

 

  1. select *  
  2. from test  
  3. where rownum <=10  

 

下面是關(guān)于rownum的介紹

Rownum和row_number() over()的使用

ROWNUM是Oracle從8開(kāi)始提供的一個(gè)偽列,是把SQL出來(lái)的結(jié)果進(jìn)行編號(hào),始終從1開(kāi)始,常見(jiàn)的用途就是用來(lái)分頁(yè)輸出.

比如

 

  1. SELECT *  
  2. FROM torderdetail a  
  3. WHERE ROWNUM <= 10  

 

這條語(yǔ)句就是輸出前10條紀(jì)錄,在這里用途上類似于sql sever的top,不過(guò)rownum對(duì)于指定編號(hào)區(qū)間的輸出應(yīng)該說(shuō)更強(qiáng)大

 

  1. SELECT *  
  2. FROM (SELECT a.*, ROWNUM rn  
  3. FROM torderdetail a)  
  4. WHERE rn >= 10 AND rn <= 20  

 

這條語(yǔ)句即是輸出Oracle查詢第10到第20條紀(jì)錄,這里之所以用rownum rn,是把rownum轉(zhuǎn)成實(shí)例,因?yàn)閞ownum本身只能用 <=的比較方式,只有轉(zhuǎn)成實(shí)列,這樣就可做 >=的比較了。

在實(shí)際用途中,常常會(huì)要求取最近的幾條紀(jì)錄,這就需要先對(duì)紀(jì)錄進(jìn)行排序后再取rownum <=

一般常見(jiàn)的

 

  1. SELECT *  
  2. FROM (SELECT a.*  
  3. FROM torderdetail a  
  4. ORDER BY order_date DESC)  
  5. WHERE ROWNUM <= 10  

 

而在CSDN曾經(jīng)發(fā)生過(guò)討論,關(guān)于取近的10條紀(jì)錄,有人給出這樣的語(yǔ)句

 

  1. SELECT a.*  
  2. FROM torderdetail a  
  3. WHERE ROWNUM <= 10  
  4. ORDER BY order_date DESC  

 

之所以會(huì)出現(xiàn)這樣的語(yǔ)句,主要是從效率上的考慮,前面條語(yǔ)句,是要進(jìn)行全表掃描后再排序,然后再取10條紀(jì)錄,后一條語(yǔ)句則不會(huì)全表掃描,只會(huì)取出10條紀(jì)錄,很明顯后條語(yǔ)句的效率會(huì)高許多。

那為什么會(huì)有爭(zhēng)議呢,那就在于在執(zhí)行順序上爭(zhēng)議,是先執(zhí)行排序取10條紀(jì)錄,還是取10條紀(jì)錄,再排序呢??jī)煞N順序取出來(lái)的結(jié)果是截然相反的,Oracle查詢前10條記錄時(shí)先排序再取10條,就是取最近的10條,而先取10條,再排序,則取出的最早的10條紀(jì)錄。對(duì)于此語(yǔ)句,普遍的認(rèn)為執(zhí)行順序是先取10條紀(jì)錄再排序的。

所以此語(yǔ)句應(yīng)該是錯(cuò)誤。但實(shí)際上并非如此,此語(yǔ)句的執(zhí)行順序和order by的字段有關(guān)系,如果你order by 的字段是pk,則是先排序,再取10條(速度比第一種語(yǔ)句快),而排序字段不是PK 時(shí),是先取10條再排序,此時(shí)結(jié)果就與要求不一樣了,所以第二種寫(xiě)法一定要在排序字段是主鍵的情況下才能保證結(jié)果正確。

Row_number() over()這個(gè)分析函數(shù)是從9I開(kāi)始提供的,一般的用途和rownum差不多。

一般寫(xiě)法row_number() over( order by order_date desc) 生成的順序和rownum的語(yǔ)句一樣,效率也一樣(對(duì)于同樣有order by 的rownum語(yǔ)句來(lái)說(shuō)),所以在這種情況下兩種用法是一樣的。

而對(duì)于分組后取最近的10條紀(jì)錄,則是rownum無(wú)法實(shí)現(xiàn)的,這時(shí)只有row_number可以實(shí)現(xiàn),row_number() over(partition by 分組字段 order by 排序字段)就能實(shí)現(xiàn)分組后編號(hào),比如說(shuō)要取近一個(gè)月的每天最后10個(gè)訂單紀(jì)錄

 

  1. SELECT *  
  2. FROM (SELECT a.*,  
  3. ROW_NUMBER () OVER (PARTITION BY TRUNC (order_date) ORDER BY order_date DESC)  
  4. rn  
  5. FROM torderdetail a)  
  6. WHERE rn <= 10  

 

Rownum的另類用法,有時(shí)候我們會(huì)遇到這種需求,要求輸出當(dāng)月的所有天數(shù),許多人會(huì)煩惱,數(shù)據(jù)庫(kù)里又沒(méi)有這樣的表,怎么輸出一個(gè)月的所有天數(shù)呢?用rownum就能解決:

 

  1. SELECT TRUNC (SYSDATE, 'MM') + ROWNUM - 1  
  2. FROM DUAL  
  3. CONNECT BY ROWNUM <= TO_NUMBER 
    (TO_CHAR (LAST_DAY (SYSDATE), 'dd'))  

 

以上的相關(guān)內(nèi)容就是對(duì)Oracle查詢前10條記錄的介紹,望你能有所收獲。

【編輯推薦】

  1. Oracle數(shù)據(jù)庫(kù)中的兩個(gè)進(jìn)程
  2. Oracle SMON進(jìn)程中系統(tǒng)監(jiān)視進(jìn)程SMON
  3. Oracle數(shù)據(jù)字典中包含的視圖有哪些
  4. Oracle數(shù)據(jù)字典的用途介紹
  5. Oracle數(shù)據(jù)庫(kù)中常用的用戶

 

責(zé)任編輯:佚名 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-04-20 14:50:04

Oracle數(shù)據(jù)庫(kù)

2010-09-26 15:15:11

SQL語(yǔ)句

2010-11-09 14:35:48

SQL Server查

2010-04-23 16:35:02

Oracle 查詢記錄

2010-11-15 13:47:13

oracle記錄加鎖

2010-10-13 16:59:28

mysql查詢

2010-04-26 17:24:37

Oracle查詢表名Oracle表列名

2010-05-06 14:31:32

Oracle數(shù)據(jù)庫(kù)

2010-05-07 11:00:25

Oracle多表查詢

2010-08-02 14:56:05

DB2基本操作指令

2010-04-26 14:43:17

Oracle遞歸條件查

2010-04-12 14:44:06

Oracle Impd

2024-01-04 07:55:32

系統(tǒng)操作日志接口

2009-04-08 10:20:43

Oracle插入查詢

2010-04-30 10:24:00

Oracle查詢指定記

2010-04-16 09:52:40

Oracle JOB

2010-04-12 13:05:56

Oracle軟件

2010-11-15 14:42:03

Oracle查詢重復(fù)記

2010-05-06 14:11:55

Oracle多條件查詢

2010-10-27 15:11:52

oracle遞歸查詢
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)