【SQL Server】系統學習之三:邏輯查詢處理階段-六段式

來源:互聯網
上載者:User

標籤:使用   io   sql   on   sp   學習   c   rom   

一、From階段

針對串連說明:

1、笛卡爾積

2、on篩選器

插播:unknown=not unknuwn 缺失的值;

篩選器(on where having)把unknown當做FALSE處理,排除在篩選結果之外。如果比較兩個null,結果是不相等的,false

check約束中當做true,例如要求某列大於0,當插入null時是成功的,認為null>0是ture。如果比較兩個null,結果是相等的,這種比較在unique約束、集合運算(例如union 、except)、排序、分組,都認為是相等的。

3、添加外部行(外串連)

二、where

由於還未分組,不能使用彙總函式;還未select,不能使用select中指定的列別名。

三、group by

四、having

五、select階段

1、彙總運算

2、discount排重

3、top

如果未指定order by,則返回的集是不確定的

當指定了with ties時,會檢查最後一行,並返回和最後一行值相同的所有行。

六、order by

這一步返回的不再是有效表,而是遊標,這也是為什麼改語句不能用在表運算式中的原因。(還記得表運算式嗎?視圖、內聯資料表值函式、派生表、cte

例外情況,是和top搭配使用時,作為擷取前n條的邏輯有限順序,此時返回的行,並未排序,不保證順序,這點需要注意。

如果不必要,不要輕易指定order by,會執行索引掃描或者執行sort運算子。

order by認為null是相等的。同時,null比已知值要小,會排在最前面。

 

延伸:

一、表運算子

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.