麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

詳解SQL Server的簡(jiǎn)單查詢語(yǔ)句

2024-08-31 01:04:23
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

對(duì)于一些原理性文章園中已有大量的文章尤其是關(guān)于索引這一塊,我也是花費(fèi)大量時(shí)間去學(xué)習(xí),對(duì)于了解索引原理對(duì)于后續(xù)理解查詢計(jì)劃和性能調(diào)優(yōu)有很大的幫助,而我們只是一些內(nèi)容進(jìn)行概括和總結(jié),這一節(jié)我們開(kāi)始正式步入學(xué)習(xí)SQL中簡(jiǎn)單的查詢語(yǔ)句,簡(jiǎn)短的內(nèi)容,深入的理解。

簡(jiǎn)單查詢語(yǔ)句

所有復(fù)雜的語(yǔ)句都是由簡(jiǎn)單的語(yǔ)句組成基本都是由SELECT、FROM、WHERE、GROUP BY、HAVING、ORDER BY等組成,當(dāng)然還包括一些謂詞等等。比如當(dāng)我們要查詢某表中所有數(shù)據(jù)時(shí)我們會(huì)像如下進(jìn)行。

SELECT * FROM TABLE

到這里是不是查詢就是從SELECT開(kāi)始呢?我們應(yīng)該從實(shí)際生活舉例,如我們需要到菜市場(chǎng)買(mǎi)菜,我們想買(mǎi)芹菜,我們應(yīng)該是到有芹菜的攤位上去買(mǎi),也就是從哪里去買(mǎi),到這里我們會(huì)發(fā)現(xiàn)上述查詢數(shù)據(jù)的順序應(yīng)該是先FROM然后是SELECT。在SQL 2012基礎(chǔ)教程中列出子句是按照以下順序進(jìn)行邏輯處理。

FROMWHEREGROUP BYHAVINGSELECTORDER BY

比如我們要查詢篩選客戶71下的訂單,我們會(huì)進(jìn)行如下查詢。

SELECT empid, YEAR(orderdate) AS orderyear, COUNT(*) AS numbers FROM Sales.OrdersWHERE custid = '71'GROUP BY empid, YEAR(orderdate)HAVING COUNT(*) > 1ORDER BY empid, orderyear

但是實(shí)際上按照我們上述所說(shuō)的順序,其邏輯化的子句是這樣的。

FROM Sales.OrdersWHERE custid = 71GROUP BY empid, YEAR(orderdate)HAVING COUNT(*) > 1SELECT empid, YEAR(orderdate) AS orderyear, COUNT(*) AS numberordersORDER BY empid, orderyear

對(duì)于博主的SQL系列并非會(huì)將SELECT、HAVING等語(yǔ)句單獨(dú)拿來(lái)講,針對(duì)的是有了一定基礎(chǔ)的人群,后續(xù)內(nèi)容也是如此,所以到了這里我們算是將簡(jiǎn)單查詢語(yǔ)句敘述完畢。但是我一直強(qiáng)調(diào)的是簡(jiǎn)短的內(nèi)容,深入的理解,所以接下來(lái)看看有些需要注意的地方。

我們看到過(guò)很多文章一直在講SQL性能問(wèn)題,比如在查詢所有數(shù)據(jù)時(shí)要列出所有列而非SELECT *,所以在本系列中,我也會(huì)在適當(dāng)?shù)娜ブv性能問(wèn)題,比如本節(jié)要講的SELECT 1和SELECT *的性能問(wèn)題。

SELECT 1和SELECT *性能探討

在數(shù)據(jù)庫(kù)中查看執(zhí)行計(jì)劃時(shí)我們通常會(huì)點(diǎn)擊【顯示估計(jì)的執(zhí)行計(jì)劃】快捷鍵是Ctrl+L,這里我們可以看到它已經(jīng)表明顯示的只是估計(jì)的執(zhí)行計(jì)劃,所以是不準(zhǔn)確的,所以為了顯示實(shí)際的執(zhí)行計(jì)劃,我們應(yīng)該啟動(dòng)【包括實(shí)際的執(zhí)行計(jì)劃】,快捷鍵是Ctrl+M,這樣才能得到比較準(zhǔn)確的執(zhí)行計(jì)劃,如下

sqlserver,查詢語(yǔ)句

查詢方式一(整表查詢)

USE TSQL2012GOIF EXISTS(SELECT 1FROM Sales.Orders)SELECT 'SELECT 1'GOIF EXISTS(SELECT *FROM Sales.Orders)SELECT 'SELECT *'GO

此時(shí)查看執(zhí)行計(jì)劃是相同的,如下:

sqlserver,查詢語(yǔ)句

查詢方式二(在索引列上條件查找)

我們對(duì)某一列創(chuàng)建索引

CREATE INDEX ix_shipnameON Sales.Orders(shipname)

接下來(lái)繼續(xù)查看其執(zhí)行計(jì)劃。

sqlserver,查詢語(yǔ)句

此時(shí)顯示查詢計(jì)劃依然一樣。我們?cè)賮?lái)看看其他查詢方式。

查詢方式三(使用聚合函數(shù))

USE TSQL2012GOIF (SELECT 1FROM Sales.OrdersWHERE shipname = 'Ship to 85-B') = 1SELECT 'SELECT 1'GOIF (SELECT COUNT(*)FROM Sales.OrdersWHERE shipname = 'Ship to 85-B') = 1SELECT 'SELECT *'GO

我們看到查詢計(jì)劃依然一樣。

sqlserver,查詢語(yǔ)句

查詢方式四(使用聚合函數(shù)Count在非索引列上查找)

USE TSQL2012GOIF (SELECT COUNT(1)FROM Sales.OrdersWHERE freight = '41.3400') = 1SELECT 'SELECT 1'GOIF (SELECT COUNT(*)FROM Sales.OrdersWHERE freight = '41.3400') = 1SELECT 'SELECT *'GO

我們看到執(zhí)行計(jì)劃還是一樣。

sqlserver,查詢語(yǔ)句

查詢方式五(子查詢)

我們看看在子查詢中二者性能如何

USE TSQL2012SELECT custid, companyname FROM Sales.Customers AS CWHERE country = N'USA' ANDEXISTS (SELECT * FROM Sales.Orders AS O WHERE O.custid = C.custid)GOSELECT custid, companyname FROM Sales.Customers AS CWHERE country = N'USA' ANDEXISTS (SELECT 1 FROM Sales.Orders AS O WHERE O.custid = C.custid)

此時(shí)結(jié)果二者查看執(zhí)行計(jì)劃還是一樣

sqlserver,查詢語(yǔ)句

查詢方式六(在視圖中查詢)

我們創(chuàng)建視圖繼續(xù)來(lái)比較SELECT 1和SELECT *的性能

USE TSQL2012GoCREATE VIEW SaleOdersViewASSELECT shipaddress,shipname,(SELECT unitprice FROM Sales.OrderDetails AS sod where sod.orderid = so.orderid) as tc3FROM Sales.Orders AS soGO

進(jìn)行視圖查詢

USE TSQL2012SELECT 1 FROM dbo.SaleOdersViewgoSELECT * FROM dbo.SaleOdersViewgo

結(jié)果執(zhí)行計(jì)劃如下:

sqlserver,查詢語(yǔ)句

此時(shí)我們通過(guò)上述圖發(fā)現(xiàn)利用視圖查詢時(shí),SELECT *的性能是如此低下占有97%,而SELECT 1才3%,這是為何呢?不明白其中原因,希望有清楚其中原因的園友能夠留下你們的評(píng)論給出合理的解釋。

SELECT 所有列和SELECT *性能探討

一直以來(lái)所有教程都在講SELECT *性能比SELECT 所有列性能低,同時(shí)也給出了合理的理由,我也一直這樣認(rèn)為,但是在查資料學(xué)習(xí)過(guò)程中,發(fā)現(xiàn)如下一段話。

I don't think there is any difference, as long as the SELECT 1/* is inside EXISTS, which really doesn't return any rows – it just returns boolean as soon as condition of the WHERE is checked.I'm quite sure that the SQL Server Query Optimizer is smart enough not to search for the unneeded meta data in the case of EXISTS.I agree that in all the other situations SELECT * shouldn't be used for the reasons Simon mentioned. Also, index usage wouldn't be optimal etc.For me EXISTS (SELECT * ..) is the only place where I allow myself to write SELECT * in production code ;)

最后一句表明SELECT *使用的唯一場(chǎng)景是在EXISTS中,看到這里顛覆我以往看的教程的想法,不太明確,真的是這樣嗎?

總結(jié)

通過(guò)以上對(duì)SELECT 1和SELECT *性能的探討,在視圖中利用SELECT *性能更加低下,同時(shí)也結(jié)合SELECT *盡量避免用,我是不是可以下結(jié)論我可以更傾向于用SELECT 1呢?第二點(diǎn)是看到上述所給的資料SELECT *在Exist中的性能是不是和一定SELECT 所有列一樣呢?這是我存在疑問(wèn)的兩個(gè)問(wèn)題,是不是我所疑問(wèn)的兩個(gè)問(wèn)題,沒(méi)有具體的答案,需要看應(yīng)用場(chǎng)景呢?那應(yīng)用場(chǎng)景又是在哪里?畢竟不是專(zhuān)業(yè)的DBA,同時(shí)對(duì)SQL也研究不深,所以希望看到此文的讀者,能給出精彩的回答,同時(shí)也讓我學(xué)習(xí)學(xué)習(xí)。

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,同時(shí)也希望多多支持VeVb武林網(wǎng)


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MSSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产午夜亚洲精品午夜鲁丝片 | 悠悠成人资源亚洲一区二区 | 国产1区2区在线观看 | 99sesese| 久草手机在线观看视频 | 黄色免费av网站 | 国产精品久久久久久影院8一贰佰 | 性爱视频在线免费 | 亚洲片在线 | 天天看成人免费毛片视频 | 亚洲第一页在线观看 | 亚洲婷婷日日综合婷婷噜噜噜 | 黄色av网站免费看 | 久久久久久亚洲国产精品 | 色戒在线版| 精品一区二区三区欧美 | 免费人成在线观看网站 | 曰韩一二三区 | 欧日韩 | 亚州视频在线 | 久久精品在线免费观看 | 视频一区 中文字幕 | 久久视频精品 | 美女扒开腿让男生桶爽网站 | 国产91影院 | 日本在线不卡一区二区三区 | 免费观看一区二区三区视频 | 日产精品久久久一区二区开放时间 | 国产精品亚洲一区二区三区久久 | 女人解衣喂奶电影 | 在线a毛片免费视频观看 | 黄视频网址 | a黄网站| 欧美成人一级 | 免看黄大片aa | 羞羞网站在线观看入口免费 | 欧美日韩免费一区 | 92看片淫黄大片欧美看国产片 | 成人电影毛片 | 成年人免费视频播放 | 超碰97最新|