標籤:複雜 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 的偽表和偽劣,簡單的分頁