--------oracle 的偽表和偽劣,簡單的分頁

來源:互聯網
上載者:User

標籤:複雜   select   情況   mysql   csharp   ack   sql   desc   from   

一: 偽表:

Dual

 目的:

  01.sql標準規定:select 語句中必須有from!必須有表名!

  02.我們查詢的資料不在任何一個表中!

  03.為了保證在使用select語句時的完整性!

      04.表的結構是單行單列

 

Mysql中可以不使用!  Oracle中必須使用!

 

二:

 

 1.RowID

 

 Selecr  rowid  from 表名;

 

    001.是一個資料類型,唯一標識一條資料在物理位置的一個ID!

 

    002.64位編碼格式的18個字元!

 

003.未儲存在表中,但是可以查詢!絕對不允許增刪改!

 

 

 

   Object             File           block      row

 

資料對象的編號     檔案編號       塊編號     行編號

 

 Oooooo              fff           bbbbbb     rrr

 

 

 

Select * from  student where rowid=’xxxxxxxxx’;

 

 

 

 2.Rownum

 

例子:

 

  小黑的id =10

 

 

 

  Select  * from  student  where  id<100

 

  肯定能找到小黑!  rownum=10

 

 

 

 

 

  Select  * from  student  where  name=”小黑” or  name=”小白”

 

肯定能找到小黑!  rownum=1

 

 

 

 

 

Select * from  student  where  rownum=1;  查詢的是student表中 第一行資料!

 

 

 

Select * from  student  where  rownum=2;  查詢的是student表中 第兩行資料! x

 

 

 

 

 

Select * from  student  where  rownum<3;  查詢的是student表中 前兩行資料!

 

 

 

 

 

Select * from  student  where  rownum>3;  查詢的是student表中 大於3的所有資料 x

 

 

 

 

 

001.返回結果集中 行的編號!

 

002.rownum只能對=1或者<n  進行操作!

 

  怎麼實現=N或者>N進行操作????

 

003.必須建立暫存資料表

 

004.讓rownum稱為暫存資料表的真正列

 

005.使用rownum的別名進行操作

 

二:分頁

 

 

 

 

 

 

 

需求:

 

查詢teacher表中薪水最高的6-10的老師資訊!

 

 

 

sql語句:1.

select * from(  select t.* rownum rn from (       select * from teacher order by sal desc   ) t  where rownum<10 )tem where rn>6

  

其中最內層的查詢SELECT * FROM TABLE_NAME表示不進行翻頁的原始查詢語句。ROWNUM <10和RN >6控制分頁查詢的每頁的範圍。

 

上面給出的這個分頁查詢語句,在大多數情況擁有較高的效率。分頁的目的就是控制輸出結果集大小,將結果儘快的返回。在上面的分頁查詢語句中,這種考慮主要體現在WHERE ROWNUM <10這句上。

 

選擇第6到10條記錄存在兩種方法,一種是上面例子中展示的在查詢的第二層通過ROWNUM <10來控制最大值,在查詢的最外層控制最小值。而另一種方式是去掉查詢第二層的WHERE ROWNUM <10語句,在查詢的最外層控制分頁的最小值和最大值。這是,查詢語句如下:

 

sql語句2:

select * from(  select t.*,rownum rn from(      select * from teacher order by sal desc  ) t)tem  where rn>5 and rn<10

  

對比這兩種寫法,絕大多數的情況下,第一個查詢的效率比第二個高得多。

 

這是由於CBO最佳化模式下,Oracle可以將外層的查詢條件推到內層查詢中,以提高內層查詢的執行效率。對於第一個查詢語句,第二層的查詢條件WHERE ROWNUM <10就可以被Oracle推入到內層查詢中,這樣Oracle查詢的結果一旦超過了ROWNUM限制條件,就終止查詢將結果返回了。

 

而第二個查詢語句,由於查詢條件BETWEEN 6 AND 10是存在於查詢的第三層,而Oracle無法將第三層的查詢條件推到最內層(即使推到最內層也沒有意義,因為最內層查詢不知道RN代表什麼)。因此,對於第二個查詢語句,Oracle最內層返回給中介層的是所有滿足條件的資料,而中介層返回給最外層的也是所有資料。資料的過濾在最外層完成,顯然這個效率要比第一個查詢低得多。

 

上面分析的查詢不僅僅是針對單表的簡單查詢,對於最內層查詢是複雜的多表聯集查詢或最內層查詢包含排序的情況一樣有效。

 

這裡就不對包含排序的查詢進行說明了,下一篇文章會通過例子來詳細說明。下面簡單討論一下多表聯合的情況。對於最常見的等值表串連查詢,CBO一般可能會採用兩種串連方式NESTED LOOP和HASH JOIN(MERGE JOIN效率比HASH JOIN效率低,一般CBO不會考慮)。在這裡,由於使用了分頁,因此指定了一個返回的最大記錄數,NESTED LOOP在返回記錄數超過最大值時可以馬上停止並將結果返回給中介層,而HASH JOIN必須處理完所有結果集(MERGE JOIN也是)。那麼在大部分的情況下,對於分頁查詢選擇NESTED LOOP作為查詢的串連方法具有較高的效率(分頁查詢的時候絕大部分的情況是查詢前幾頁的資料,越靠後面的頁數訪問幾率越小)。

 

因此,如果不介意在系統中使用HINT的話,可以將分頁的查詢語句改寫為:

 

SELECT /*+ FIRST_ROWS */ * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A WHERE ROWNUM <= 40 ) WHERE RN >= 21

 

--------oracle 的偽表和偽劣,簡單的分頁

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.