国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  應聘面試  >  Python面試題  > SQL的select語句完整的執行順序

SQL的select語句完整的執行順序

來源:千鋒教育
發布人:wjy
時間: 2022-08-22 14:35:15 1661150115

SQL語言不同于其他編程語言的最明顯特征是處理代碼的順序。

在大多數據庫語言中,代碼按編碼順序被處理。但在SQL語句中,第一個被處理的子句式FROM,而不是第一出現的SELECT。 

SQL查詢處理的步驟序號: 

(1) FROM 

(2) JOIN 

(3) ON 

(4) WHERE 

(5) GROUP BY 

(6) WITH {CUBE|ROLLUP} 

(7) HAVING

(8) SELECT 

(9) DISTINCT

(9) ORDER BY 

(10) 以上每個步驟都會產生一個虛擬表,該虛擬表被用作下一個步驟的輸入。這些虛擬表對調用者(客戶端應用程序或 者外部查詢)不可用。只有最后一步生成的表才會會給調用者。

如果沒有在查詢中指定某一個子句,將跳過相應的步驟。 邏輯查詢處理階段簡介: 

1、 FROM:對 FROM 子句中的前兩個表執行笛卡爾積(交叉聯接),生成虛擬表 VT1。

2、 ON:對 VT1 應用ON 篩選器,只有那些使為真才被插入到 TV2。

3、 OUTER (JOIN):如果指定了OUTER JOIN(相對于 CROSS JOIN 或 INNER JOIN),保 留表中未找到匹配的行將作為外部行添加到 VT2,生成 TV3。

如果 FROM 子句包含兩個以上的表,則對上一個聯 接生成的結果表和下一個表重復執行步驟 1 到步驟 3,直到處理完所有的表位置。

4、 WHERE:對 TV3 應用 WHERE 篩選器,只有使為 true 的行才插入 TV4。

5、 GROUP BY:按GROUP BY 子句中的列列表對 TV4 中的行進行分組,生成 TV5。

6、 CUTE|ROLLUP:把超組插入VT5,生成 VT6。

SQL的select語句完整的執行順序

7、 HAVING:對 VT6 應用 HAVING 篩選器,只有使為 true 的組插入到 VT7。

8、 SELECT:處理SELECT 列表,產生 VT8。

9、 DISTINCT:將重復的行從VT8 中刪除,產品 VT9。

10、 ORDERBY:將VT9 中的行按ORDERBY 子句中的列列表順序,生成一個游標(VC10)。

11、 TOP:從VC10 的開始處選擇指定數量或比例的行,生成表 TV11,并返回給調用者。 where 子句中的條件書寫順序

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
【Python面試題】談談你對“猴子補丁”(monkey patching)的理解

“猴子補丁”是動態類型語言的一個特性,代碼運行時在不修改源代碼的前提下改變代碼中的方法、屬性、函數等以達到熱補?。╤ot patch)的效果。詳情>>

2022-08-23 10:29:17
【Python面試題】使用Python代碼實現遍歷一個文件夾的操作

Python標準庫os模塊的walk函數提供了遍歷一個文件夾的功能,它返回一個生成器。import os g = os.walk('/Users/Hao/Downloads/') for path, dir...詳情>>

2022-08-23 10:29:09
【Python面試題】如何理解python中的封裝,繼承,多態的

封裝:封裝就是把對象的屬性和行為結合成一個獨立的整體,把內部的實現細節隱藏起來,不能被外界所看見,調用的人只能執行,而看不到實現的細節...詳情>>

2022-08-23 10:29:06
【Python面試題】運行下面的代碼是否會報錯

擴展:如果不希望代碼運行時動態的給對象添加新屬性,可以在定義類時使用__slots__魔法。例如,我們可以在上面的A中添加一行__slots__ = ('__va...詳情>>

2022-08-23 10:29:03
【Python面試題】閱讀下面的代碼說出運行結果。

在沒有多重繼承的情況下,向對象發出一個消息,如果對象沒有對應的方法,那么向上(父類)搜索的順序是非常清晰的。如果向上追溯到object類(所...詳情>>

2022-08-23 10:29:00