千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當前位置:首頁  >  應(yīng)聘面試  >  Python面試題  > SQL的select語句完整的執(zhí)行順序

SQL的select語句完整的執(zhí)行順序

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

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

在大多數(shù)據(jù)庫語言中,代碼按編碼順序被處理。但在SQL語句中,第一個被處理的子句式FROM,而不是第一出現(xiàn)的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) 以上每個步驟都會產(chǎn)生一個虛擬表,該虛擬表被用作下一個步驟的輸入。這些虛擬表對調(diào)用者(客戶端應(yīng)用程序或 者外部查詢)不可用。只有最后一步生成的表才會會給調(diào)用者。

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

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

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

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

如果 FROM 子句包含兩個以上的表,則對上一個聯(lián) 接生成的結(jié)果表和下一個表重復(fù)執(zhí)行步驟 1 到步驟 3,直到處理完所有的表位置。

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

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

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

SQL的select語句完整的執(zhí)行順序

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

8、 SELECT:處理SELECT 列表,產(chǎn)生 VT8。

9、 DISTINCT:將重復(fù)的行從VT8 中刪除,產(chǎn)品 VT9。

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

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

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
【Python面試題】談?wù)勀銓Α昂镒友a丁”(monkey patching)的理解

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

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

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

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

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

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

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

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

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

2022-08-23 10:29:00
快速通道