如何解決SqlServer表單查詢問題

這篇文章主要介紹了如何解決SqlServer表單查詢問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

目前累計服務客戶成百上千,積累了豐富的產(chǎn)品開發(fā)及服務經(jīng)驗。以網(wǎng)站設計水平和技術(shù)實力,樹立企業(yè)形象,為客戶提供成都網(wǎng)站設計、網(wǎng)站制作、外貿(mào)營銷網(wǎng)站建設、網(wǎng)站策劃、網(wǎng)頁設計、網(wǎng)絡營銷、VI設計、網(wǎng)站改版、漏洞修補等服務。創(chuàng)新互聯(lián)公司始終以務實、誠信為根本,不斷創(chuàng)新和提高建站品質(zhì),通過對領(lǐng)先技術(shù)的掌握、對創(chuàng)意設計的研究、對客戶形象的視覺傳遞、對應用系統(tǒng)的結(jié)合,為客戶提供更好的一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進步。

Q1:表StudentScores如下,用一條SQL語句查詢出每門課都大于80分的學生姓名

如何解決SqlServer表單查詢問題

Q2:表DEMO_DELTE如下,刪除除了自動編號不同,其他都相同的學生冗余信息

如何解決SqlServer表單查詢問題

Q3:Team表如下,甲乙丙丁為四個球隊,現(xiàn)在四個球?qū)M行比賽,用一條sql語句顯示所有可能的比賽組合

如何解決SqlServer表單查詢問題

Q4:請考慮如下SQL語句在Microsoft SQL Server 引擎中的邏輯處理順序

USE TSQLFundamentals2008

SELECT empid,YEAR(orderdate) AS orderyear,COUNT(*) numorders
FROM Sales.Orders
WHERE custid=71
GROUP BY empid,YEAR(orderdate)
HAVING COUNT(*)>1
ORDER BY empid,orderyear

本篇文章將剖析一般查詢過程中,涉及到的處理邏輯子句,主要包括FROM,WHERE,GROUP BY,HAVING,SELECT,ORDER BY,TOP,OVER等子句。

2 SELECT語句的元素

2.1 常規(guī)查詢子句和邏輯處理順序

對數(shù)據(jù)表進行檢索查詢時,查詢語句一般包括FROM,WHERE,GROUP BY,HAVING,SELECT,ORDER BY,TOP,OVER等子句,請考慮如下例子的邏輯處理順序。

USE TSQLFundamentals2008

SELECT empid,YEAR(orderdate) AS orderyear,COUNT(*) numorders
FROM Sales.Orders
WHERE custid=71
GROUP BY empid,YEAR(orderdate)
HAVING COUNT(*)>1
ORDER BY empid,orderyear

如上代碼,在SQL中邏輯處理順序如下:

USE TSQLFundamentals2008

FROM Sales.Orders
WHERE custid=71
GROUP BY empid,YEAR(orderdate)
HAVING COUNT(*)>1
SELECT empid,YEAR(orderdate) AS orderyear,COUNT(*) numorders
ORDER BY empid,orderyear

邏輯處理順序可歸結(jié)為如下:

如何解決SqlServer表單查詢問題

注釋:

a.在常規(guī)編程語言中,如c++,java,c#等,程序按照“從上往下”的順序一步一步地執(zhí)行,然而在SQL中,SELECT語句所處位置雖然在最開始,卻不是在最先執(zhí)行的;

b.邏輯處理順序的每一步返回的結(jié)果集均是緊接著該步語句的下一步語句要執(zhí)行的結(jié)果集;

c.FROM獲取數(shù)據(jù)源(或者數(shù)據(jù)表),WHERE在FROM基礎(chǔ)上過濾條件,GROUP BY在WHERE的基礎(chǔ)上按照至少一列對集合進行分組,HAVING在GROUP BY基礎(chǔ)上,對已經(jīng)分組的集合進行過濾,SELECT語句在HAVING基礎(chǔ)上檢索,ORDER BY在SELECT基礎(chǔ)上按照一定條件進行排序;

2.2 部分查詢子句講解

2.2.1 FROM子句

a.用數(shù)據(jù)庫架構(gòu)在限定代碼中的對象名稱,即使不用數(shù)據(jù)庫架構(gòu)限定,Sql Server也會隱式解析它,代價更高,初次之外,如果對象名相同,沒有架構(gòu)限定,會產(chǎn)生歧義;

b.FROM * 性能比 FROM conum_name性能低;

c.FROM查詢得到的結(jié)果集順序是隨機的;

2.2.2 WHERE子句

a.過濾FROM階段返回的行;

b.WHERE 謂詞或邏輯表達式;

c.WHERE子句對查詢性能有重要影響,在過濾表達式基礎(chǔ)上,Sql Server會計算使用什么索引來訪問請求的數(shù)據(jù);

d.掃描整張表,返回所有可能的行,在客戶端過濾,開銷比較大,如產(chǎn)生大量的網(wǎng)絡傳輸流量;

e.T-SQL使用三值謂詞邏輯(true,false,unknown);

2.2.3 GROUP BY子句

a.GROUP BY階段將上一階段邏輯查詢處理返回的行按“組”進行組合,每個組由在GROUP BY子句中指定的個元素決定;

b.如果查詢語句中涉及到分組,那么GROUP BY階段之后測所有階段(包括HAVING、SELECT以及ORDER BY)的操作對象將是組,而不是單獨的行。每個組最終表示為查詢結(jié)果集中的一行;

c.GROUP BY階段之后處理的子句中指定的所有表達式務必保證為每個組只返回一個標量(單值)。以GROUP BY列表中的元素為基礎(chǔ)的表達式滿足這一要求,因為按照定義,在每個組中GROUP BY元素只唯一出現(xiàn)一次;

d.聚合函數(shù)只為每個組返回一個值,所以一個元素如果不再GROUP BY列表中出現(xiàn),就只能作為聚合函數(shù)(COUNT、SUM、AVG、MIN和MAX)的輸入。(注意:若有GROUP BY子句,聚合函數(shù)只操作具體的每組,而非所有組);

e.所有聚合函數(shù)都會忽略NULL,但COUNT(*)除外;

f.在聚合函數(shù)中,可以使用distinct來處理非重復數(shù),如count(distinct vary);

2.2.4 HAVING子句

a.HAVING子句用于指定對組進行過濾的謂詞或邏輯表達式,這與WHERE階段對單獨的行進行過濾相對應;

b.因為HAVING子句是在對行進行分組后處理的,所以可以在邏輯表達式中引用聚合函數(shù),如 HAVING COUNT(*)>1,意味著HAVING階段過濾器只保留包含多行的組;

2.2.5 SELECT 子句

a.SELECT子句用于指定需要在查詢返回的結(jié)果集中包含的屬性(列);

b.SELECT子句返回列的名稱類型:

直接基于正在查詢的表的各個列三種方式定義別名,推薦使用AS。<表達式>AS<別名>;<別名>=<表達式>(別名 等號 表達式);<表達式> <別名>(表達式 空格 別名)沒有名字的列

c.在關(guān)系模型中,所有操作和關(guān)系都基于關(guān)系代數(shù)和關(guān)系(集合)中的結(jié)果,但在SQL中,情況略有不同,因SELECT查詢并不保證返回一個真正的集合(即,由唯一行組成的無序集合)。首先,SQL不要求表必須符合集合條件。SQL表可以沒有鍵,行也不一定具有唯一性,在這些情況下表都不是集合,而是多集(multiset)或包(bag)。但即使正在查詢的表具有主鍵、也符合集合的條件,針對這個表的SELECT查詢?nèi)稳豢赡芊祷匕貜偷慕Y(jié)果。在描述SELECT查詢的輸出時,經(jīng)常會使用結(jié)果集這個屬于,不過,結(jié)果集并不一定非得嚴格滿足數(shù)學意義上的集合條件;

d.DISTINCT約束,確保行的唯一性,刪除重復的行;

e.盡量不用SELECT * 形式查詢所有列,而盡量用列明;

2.2.6 ORDER BY

a.理解SQL最重要的一點就是要明白表不保證是有序的,因為表是為了代表一個集合(如果有重復項,則是多集),而集合是無序的。這意味著,如果在查詢表時不指定一個ORDER BY子句,那么雖然查詢可以返回一個結(jié)果表,但SQL Server可以自由地按任意順序?qū)Y(jié)果張的行進行排序;

b.在ORDRTB BY中使用ASC代表升序,DESC代表降序,默認情況是升序;

c.帶有ORDER BY子句的查詢會生成一種ANSI稱之為游標(cursor)的結(jié)果(一種非關(guān)系結(jié)果,其中的行具有固定的順序)。在SQL中的某些語言元素和運算預期只對查詢的表結(jié)果進行處理,而不能處理游標,如表表達式和集合運算;

3 問題答案

Q1:KEY

--方法1
select distinct studentName 
from StudentScores
where studentName not in 
(
select distinct studentName 
from StudentScores 
where courseGrades<=80
)

--方法2
select studentName 
from StudentScores 
group by studentName 
having min(courseGrades)>80

Q2:KEY

 DELETE DEMO_DELTE
 WHERE ID 
 NOT IN(
 SELECT min(ID) 
 FROM DEMO_DELTE_2 
GROUP BY xuehao,XM,kcbh,kcmc,fs)

Q3:KEY

SELECT team1.TeamName,team2.TeamName
 FROM Team team1,Team team2
 WHERE team1.TeamName<team2.TeamName

Q4:KEY

參照第2章分析。

4 參考文獻

【01】Microsoft SqlServer 2008技術(shù)內(nèi)幕:T-SQL語言基礎(chǔ)

【02】Microsoft SqlServer 2008技術(shù)內(nèi)幕:T-SQL查詢

【03】程序員的SQL經(jīng)典

PS:下面給大家分享一段代碼

sqlserver查詢數(shù)據(jù)的所有表名和行數(shù)

//查詢所有表明select name from sysobjects where xtype='u'
select * from sys.tables//查詢數(shù)據(jù)庫中所有的表名及行數(shù)
SELECT a.name, b.rows
FROM sysobjects AS a INNER JOIN sysindexes AS b ON a.id = b.id
WHERE (a.type = 'u') AND (b.indid IN (0, 1))
ORDER BY a.name,b.rows DESC
//查詢所有的標明及空間占用量\行數(shù)
select
object_name(id) tablename,
8*reserved/1024 reserved,
rtrim(8*dpages)+'kb' used,
8*(reserved-dpages)/1024 unused,
8*dpages/1024-rows/1024*minlen/1024 free,
rows
--,*
from sysindexes
where indid=1
order by tablename,reserved desc

感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何解決SqlServer表單查詢問題”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學習!

新聞名稱:如何解決SqlServer表單查詢問題
網(wǎng)頁鏈接:http://muchs.cn/article48/ghsohp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站、做網(wǎng)站軟件開發(fā)、品牌網(wǎng)站制作、定制網(wǎng)站網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設