數據庫技術與應用(基礎查詢查詢結果操作)_第1頁
數據庫技術與應用(基礎查詢查詢結果操作)_第2頁
數據庫技術與應用(基礎查詢查詢結果操作)_第3頁
數據庫技術與應用(基礎查詢查詢結果操作)_第4頁
數據庫技術與應用(基礎查詢查詢結果操作)_第5頁
已閱讀5頁,還剩10頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

張俊杰莊德俊SQL技術與應用——數據庫中的數據使用T-SQL語言簡介第一節(jié)基礎查詢第二節(jié)

第三節(jié)目錄Contents復雜查詢第二節(jié)基礎查詢12簡單查詢條件查詢3

查詢結果操作3查詢結果操作(1)對查詢結果進行排序對查詢結果集的相應列進行排序,將查詢結果按一個或多個列值的順序輸出語句格式:Select<字段列表>from<表名>where<邏輯表達式>Orderby<排序字段>[asc|desc]【說明】1.orderby子句中的排序字段可以表示排序列或列的別名和表達式,當有多個排序列時,

每個排序列之間使用逗號隔開,而且各列后都可以跟一個排序要求。2.asc關鍵字表示升序,desc關鍵字表示降序,默認為asc。3.使用orderby子句查詢時,若存在Null值,則空值被視為最小的可能值。4.ntext、text、image、xml類型的列不能用于orderby子句?!竟δ堋渴褂胦rderby子句可以對查詢結果集的相應列進行排序3(1)對查詢結果進行排序【例1】:查詢學號、課程號、成績,并按成績升序排列

selectsno,cno,scorefromscorderbyscore【例2】:查詢學生的姓名、班級、查詢結果按班名升序、

姓名降序處理

selectsname,classfromsorderbyclass,snamedesc(例1)(例2)查詢結果操作3查詢結果操作(2)查詢結果生成新表使用Select查詢獲取的數據可以作為一個新表來使用。在select語句中,可使用into關鍵字將查詢結果集生成新表。語句格式:Select<字段列表>into<新表名>from<表名>【功能】使用into關鍵字將查詢結果集生成新表3(2)查詢結果生成新表【例1】:創(chuàng)建補考學生表BK,包括學號、課程號、成績。

selectsno,cno,scoreintobkfromscwherescore<=60select*frombk(例1)查詢結果操作3查詢結果操作(3)使用聚合函數查詢聚合函數對一組值執(zhí)行計算,并返回單個值。常用聚合函數:Count:求個數,返回數據的數量。

//例:count(1,3,5)=3Sum:求和,返回表達式中所有值的和。

//例:sum(1,3,5)=9Avg:求平均值,返回表達式中所有值的平均值。//例:avg(1,3,3,5)=3Max:求最大值,返回表達式中所有值的最大值。//例:max(1,3,5)=5Min

:求最大值,返回表達式中所有值的最小值。//例:min(1,3,5)=1【功能】1.除count函數以外,其他聚合函數都會忽略空值。2.使用聚合函數時可以使用AS關鍵字設置別名。3.聚合函數中可以使用表達式。3(3)使用聚合函數查詢【例1】:查詢所有學生選修課程數量、總分、平均分、最高分、最低分。

selectCOUNT(*)as選課數,SUM(score)as總分,AVG(score)as平均分,MAX(score)as最高分,MIN(score)as最低分fromsc查詢結果操作3查詢結果操作(4)對查詢結果進行分組使用groupby子句可以對查詢結果進行分組,如果select子句中包含聚合函數,則計算分組的匯總值。語句格式:Select<字段列表>from<表名>where<邏輯表達式>Groupby<分類字段>【說明】1.groupby子句中的分類字段可以包含多個列。2.select后面的檢索內容必須是聚合函數或groupby子句中的分類字段。3.如果select子句中包含聚合函數,則groupby將計算每組的匯總值。3(4)對查詢結果進行分組【例2】:查詢每個學生選修課程數量、總分、最高分。

selectsno,count(*)as選課數,sum(score)as總分,maxas最高分fromscgroupbysno查詢結果操作【例1】:查詢學生表S中男生、女生的人數

selectsex,count(*)as人數fromsgroupbysex(例1)(例2)3(4)對查詢結果進行分組【例2】:要求對學生表中的數據進行分組匯總,按學生出生年份進行分組,統(tǒng)計各年份對應的學

生數量。提示:使用datepart函數返回日期中的指定部分,yyyy代表年份。

selectDATEPART(yyyy,birthday)as年,COUNT(*)as人數fromsgroupbyDATEPART(yyyy,birthday)查詢結果操作3查詢結果操作(5)對分組結果進行過濾having子句用來指定組或者聚合的搜索條件,通常在groupby子句中使用語句格式:Select<字段列表>from<表名>where<邏輯表達式>Groupby<分類字段>[having<檢索條件>]【說明】使用having子句查詢與where關鍵字類似,都是在關鍵字后面插入條件表達式來

規(guī)范查詢結果,兩者的不同體現(xiàn)在一下幾點:1.where關鍵字針對列的數據,having則是針對結果組。2.where關鍵字不能與聚合函數一起使用,而having一般都與聚合函數結合使用。3.where關鍵字在分組前對數據進行過濾,having語句只過濾分組后的數據。3(5)對分組結果進行過濾【例2】:查詢選修2門以上課程的學生學號selectsnofromscgroupbysnohavingcount(*)>=2查詢結果操作【例1】:查詢平均成績及格的學生所選課程的數量、總分

及最高分和最低分

selectsno,count(*)as選課數,sum(score)as

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論