久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

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

手機(jī)站
千鋒教育

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

千鋒教育

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

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

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

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

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

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

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

在大多數(shù)據(jù)庫(kù)語(yǔ)言中,代碼按編碼順序被處理。但在SQL語(yǔ)句中,第一個(gè)被處理的子句式FROM,而不是第一出現(xiàn)的SELECT。 

SQL查詢處理的步驟序號(hào): 

(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) 以上每個(gè)步驟都會(huì)產(chǎn)生一個(gè)虛擬表,該虛擬表被用作下一個(gè)步驟的輸入。這些虛擬表對(duì)調(diào)用者(客戶端應(yīng)用程序或 者外部查詢)不可用。只有最后一步生成的表才會(huì)會(huì)給調(diào)用者。

如果沒(méi)有在查詢中指定某一個(gè)子句,將跳過(guò)相應(yīng)的步驟。 邏輯查詢處理階段簡(jiǎn)介: 

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

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

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

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

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

5、 GROUP BY:按GROUP BY 子句中的列列表對(duì) TV4 中的行進(jìn)行分組,生成 TV5。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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