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

手機(jī)站
千鋒教育

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

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

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

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

當(dāng)前位置:首頁  >  應(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 中的行進(jìn)行分組,生成 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 子句中的列列表順序,生成一個游標(biāo)(VC10)。

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

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(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(bǔ)丁”(monkey patching)的理解

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

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

Python標(biāo)準(zhǔn)庫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é)合成一個獨(dú)立的整體,把內(nèi)部的實現(xiàn)細(xì)節(jié)隱藏起來,不能被外界所看見,調(diào)用的人只能執(zhí)行,而看不到實現(xiàn)的細(xì)節(jié)...詳情>>

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

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

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

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

2022-08-23 10:29:00
快速通道
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
日本久久综合久久鬼色 | 亚洲欧美中文字幕专区 | 在线播放中文有码国产 | 午夜精品久久久久久不卡 | 中文字字幕专区在线精品乱码 | 午夜精品视频在线观看 |