關於SELECT執行順序的問題!

 最近準備數據庫DBA的面試,碰到考察select語句執行順序的問題,見附,回頭查詢了下王珊老師的《數據庫系統概論》,裏面給SELECT的定義格式爲:
SELECT[ALL|DISTINCT]<目標列表達式>[,<目標列表達式>]…
FROM<表名或視圖名>[,<表名或視圖名>]…
[WHERE<條件表達式>]
[GROUP BY<列名1>][HAVING<條件表達式>]
[ORDER BY<列名2>][ASC|DESC]
文中其對SELECT語句的含義解釋爲:根據where子句的條件表達式,從FROM子句指定的基本表或視圖中找出滿足條件的元組,再按Select子句中的目標列表達式,選出元組中的屬性值形成結果表。如果有GROUP子句,則將結果按<列名1>的值進行分組,該屬性列值相等的元組爲一個組。通常會在每組中作用集函數(sum,count,max,min等)。如果GROUP子句帶HAVING短語,則只有滿足指定條件的組纔會輸出。如果有ORDER子句,則結果表還要按<列名2>的值的升序或降序排序。
我反覆體會了好幾遍,感覺這樣的敘述很容易讓人得出SELECT語句執行順序爲:from,where,目標列表達式,group,使用聚集函數計算,having,order的結論,但是這樣的執行順序總感覺特別扭,與所體會的SELECT的用法不那麼匹配,通過網絡調研,得到如下結果,特分享出來,希望對大家有所幫助:
1、from子句組裝來自不同數據源的數據;
2、where子句基於指定的條件對記錄行進行篩選;
3、group by子句將數據劃分爲多個分組;
4、使用聚集函數進行計算;
5、使用having子句篩選分組;
6、計算所有的表達式;
7、使用order by對結果集進行排序。
有了上述這樣的認識,我們來做附錄上的兩到SQL面試題,答案將很容易,分別是E,C
1)in a select statement that includes a where clause,where is the group by clause placed in the select statement?______。
A. immediately after the select clause
B. before the where clause
C. before the from clause
D. after the order by clause
E. after the where clause
2)in a select statement that includes a where clause,where is the order by clause placed in the select statement?______.
A.immediately after the select clause
B.before the where clause
C.after all clause
D.after the where clause
E.before the from clause
 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章