九九热最新网址,777奇米四色米奇影院在线播放,国产精品18久久久久久久久久,中文有码视频,亚洲一区在线免费观看,国产91精品在线,婷婷丁香六月天

《SQL語言基礎》PPT課件

上傳人:san****019 文檔編號:16020434 上傳時間:2020-09-15 格式:PPT 頁數(shù):194 大?。?.47MB
收藏 版權(quán)申訴 舉報 下載
《SQL語言基礎》PPT課件_第1頁
第1頁 / 共194頁
《SQL語言基礎》PPT課件_第2頁
第2頁 / 共194頁
《SQL語言基礎》PPT課件_第3頁
第3頁 / 共194頁

下載文檔到電腦,查找使用更方便

14.9 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《《SQL語言基礎》PPT課件》由會員分享,可在線閱讀,更多相關《《SQL語言基礎》PPT課件(194頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、數(shù)據(jù)庫管理系統(tǒng),授課教師 吳濤,第4章 SQL語言基礎,4.1 SQL語言概述 4.2系統(tǒng)提供的數(shù)據(jù)類型 4.3 用戶定義數(shù)據(jù)類型 4.4 T-SQL語言的一些基礎知識 4.5 變量,2/34,概述,SQL(Structured Query Language)是用戶操作關系數(shù)據(jù)庫的通用語言。 包含數(shù)據(jù)定義、數(shù)據(jù)查詢、數(shù)據(jù)操作和數(shù)據(jù)控制等與數(shù)據(jù)庫有關的全部功能。 已成為關系數(shù)據(jù)庫的標準語言。 所有的關系數(shù)據(jù)庫管理系統(tǒng)都支持SQL。,3/34,4.1 SQL語言概述,4.1.1 SQL語言的發(fā)展 4.1.2 SQL語言的特點 4.1.3 SQL語言功能概述,4/34,4.1.1 SQL語言的發(fā)展,

2、1986年10月美國ANSI公布最早的SQL標準。 1989年4月,ISO提出了具備完整性特征的SQL,稱為SQL-89(SQL1)。 1992年11月,ISO又公布了新的SQL標準,稱為SQL-92(SQL2) (以上均為關系形式)。 1999年頒布SQL-99(SQL3),是SQL92的擴展。,5/34,4.1.2 SQL語言的特點,1. 一體化 2. 高度非過程化 3. 簡潔 4. 使用方式多樣,6/34,4.1.3 SQL語言功能概述,四部分:數(shù)據(jù)定義功能、數(shù)據(jù)控制功能、數(shù)據(jù)查詢功能和數(shù)據(jù)操縱功能。,7/34,4.2 系統(tǒng)提供的數(shù)據(jù)類型,4.2.1 數(shù)值類型 4.2.2 字符串類型 4

3、.2.3 日期時間類型 4.2.4 貨幣類型,8/34,準確數(shù)值類型,9/34,近似數(shù)值數(shù)類型,10/34,字符串類型,普通編碼字符串類型 統(tǒng)一字符編碼字符串類型 二進制字符串類型,11/34,普通編碼字符串類型,說明:如果在使用char(n)或varchar(n)類型時未指定n,則默認長度為1。如果在使用CAST和CONVERT函數(shù)時未指定n,則默認長度為30。,12/34,統(tǒng)一字符編碼字符串類型,13/34,二進制字符串類型,14/34,日期時間類型,15/34,日期時間類型(續(xù)),16/34,貨幣類型,17/34,4.3 用戶定義數(shù)據(jù)類型,實際上是為系統(tǒng)數(shù)據(jù)類型起了個別名,因此也稱為別名

4、類型。 當在多個表中存儲語義相同的列時,一般要求這些列的數(shù)據(jù)類型和長度應該完全一致。為避免語義相同的列在不同的地方定義不一致,可以使用用戶定義的數(shù)據(jù)類型。,18/34,創(chuàng)建用戶定義數(shù)據(jù)類型,CREATE TYPE schema_name. type_name FROM base_type ( precision , scale ) NULL | NOT NULL 例1創(chuàng)建一個名為telephone的數(shù)據(jù)類型,其相應的系統(tǒng)數(shù)據(jù)類型為:char(8),不允許空 CREATE TYPE telephone FROM CHAR(8) NOT NULL,19/34,4.4 T-SQL語言的一些基

5、礎知識,語句批 一組SQL語句集合 作為一個執(zhí)行單元 結(jié)束標記:GO 腳本 存儲在文件中的SQL語句集合 注釋 單行注釋符:-- 多行注釋符:/* */,20/34,4.5 變量,4.5.1變量的種類 4.5.2 變量的聲明與賦值,21/34,變量種類,(1)局部變量: 變量名:用戶使用 (2)全局變量: 變量名:系統(tǒng)用于記錄信息,22/34,聲明局部變量,DECLARE local_variable AS data_type | = value , ... n local_variable:變量名。必須以“”開頭,且最多可包含128個字符。 data_type:任何系統(tǒng)提供的數(shù)據(jù)類型

6、或用戶定義的數(shù)據(jù)類型。但不能是text、ntext或image。,23/34,給變量賦值,SET local_variable = expression | local_variable += | -= | *= | /= | %= | ::= column_name AS computed_column_expression,36/38,基本表定義(續(xù)), ::= column_name COLLATE collation_name NULL | NOT NULL CONSTRAINT constraint_name DEFAULT constant_express

7、ion | IDENTITY ( seed ,increment ) ,37/38,示例:創(chuàng)建學生表,CREATE TABLE Student ( Sno CHAR(7) PRIMARY KEY, Sname NCHAR(5)NOT NULL, SID CHAR(18)UNIQUE, Ssex NCHAR(1)DEFAULT 男, Sage TINYINTCHECK(Sage=15 AND Sage<=45), Sdept NVARCHAR(20) ),38/38,創(chuàng)建課程表,CREATE TABLE Course ( Cno CHAR(6) PRIMARY KEY, Cname

8、 NVARCHAR(20)NOT NULL, Credit NUMERIC(3,1)CHECK(Credit0), Semester TINYINT ),39/38,創(chuàng)建選課表,CREATE TABLE SC ( Sno CHAR(7) NOT NULL, Cno CHAR(6) NOT NULL, Grade TINYINT, PRIMARY KEY (Sno, Cno), FOREIGN KEY (Sno) REFERENCES Student(Sno), FOREIGN KEY (Cno) REFERENCES Course(Cno) ),40/38,示例:創(chuàng)建有計算列的表,CREATE

9、 TABLE CompTable ( low int, high int, myavg AS (low + high)/2 ),41/38,示例:創(chuàng)建包含標識列的表,標識列的種子值為1,增量值也為1。 CREATE TABLE IDTable ( SID INT IDENTITY(1,1) NOT NULL, Name VARCHAR(20) ),42/38,說明,一般情況下,在插入數(shù)據(jù)時不能為標識列提供值。標識列的值是系統(tǒng)自動生成的。 如果確實要為標識列提供值,則必須將表的IDENTITY_INSERT屬性設置為ON(默認時該屬性的值為OFF)。 SET IDENTITY_INSERT d

10、atabase_name. schema_name . table ON | OFF ,43/38,修改表結(jié)構(gòu),可以使用ALTER TABLE語句實現(xiàn)。 ALTER TABLE語句可以對已定義的表進行添加列、刪除列、修改列定義等操作,也可以進行添加和刪除約束的操作。,44/38,,ALTER TABLE database_name.schema_name.| schema_name . table_name ALTER COLUMN column_name type_schema_name. type_name ( precision , scale | max ) NULL |

11、NOT NULL | ADD | | ,...n | DROP CONSTRAINT constraint_name | COLUMN column_name ,...n ; ,45/38,示例,例2為SC表添加“修課類別”列,此列的定義為:Type NCHAR(1),允許空。 ALTER TABLE SC ADD Type NCHAR(1) NULL 例3將新添加的Type列的數(shù)據(jù)類型改為NCHAR(2)。 ALTER TABLE SC ALTER COLUMN Type NCHAR(2),46/38,示例,例4為Type列添加限定取值范圍為必修、重

12、修、選修的約束。 ALTER TABLE SC ADD CHECK(Type IN (必修, 重修, 選修) ) 例5刪除SC表的“Type”列。 ALTER TABLE SC DROP COLUMN Type,47/38,刪除表,DROP TABLE , 例6刪除test表。 DROP TABLE test 注意:如果被刪除的表中有其他表對它的外鍵引用約束,則必須先刪除外鍵所在的表,然后再刪除被引用的表。,48/38,5.2 分區(qū)表,分區(qū)表是把數(shù)據(jù)按某種標準劃分成區(qū)域存儲在不同的文件組中,使用分區(qū)可以快速而有效地管理和訪問數(shù)據(jù)子集,從而使大型表或索引更易于管理。 合理的使用分區(qū)會在很大

13、程度上提高數(shù)據(jù)庫的性能。 分區(qū)表是將表中的數(shù)據(jù)按水平方式劃分成不同的子集,這些數(shù)據(jù)子集存儲在數(shù)據(jù)庫的一個或多個文件組中。,49/38,比較適于進行分區(qū)的情況,表中數(shù)據(jù)量大; 該表包含(或?qū)┮远喾N不同方式使用的大量數(shù)據(jù)。 數(shù)據(jù)是分段的,比如數(shù)據(jù)以年為分隔。 對表的常規(guī)維護操作只針對表的一個數(shù)據(jù)子集。,50/38,分區(qū)表特點,分區(qū)表是從物理上將一個大表分成幾個小表,但從邏輯上來看,還是一個大表。 對用戶而言,所面對的依然是一個大表,他們不需要考慮操作的年份對應的小表,用戶只要將記錄插入到大表邏輯表中就可以了,數(shù)據(jù)庫管理系統(tǒng)會自動將數(shù)據(jù)放置到它對應的那個物理小表中。,51/38,創(chuàng)建分區(qū)表步驟

14、,1創(chuàng)建分區(qū)函數(shù)。告訴SQL Server以什么方式對表進行分區(qū)。 2創(chuàng)建分區(qū)方案。將分區(qū)函數(shù)生成的分區(qū)映射到文件組中去。分區(qū)函數(shù)的作用是告訴SQL Server如何將數(shù)據(jù)進行分區(qū),而分區(qū)方案的作用則是告訴SQL Server將已分區(qū)的數(shù)據(jù)放在哪個文件組中。 3使用分區(qū)方案創(chuàng)建表。 說明:在創(chuàng)建分區(qū)表之前,最好先創(chuàng)建數(shù)據(jù)庫文件組。,52/38,1. 創(chuàng)建分區(qū)函數(shù),CREATE PARTITION FUNCTION partition_function_name ( input_parameter_type ) AS RANGE LEFT | RIGHT FOR VALUES ( boundar

15、y_value , n ),53/38,示例,例1在 int 列上創(chuàng)建左側(cè)分區(qū)函數(shù)。下列分區(qū)函數(shù)將表分為四個分區(qū)。 CREATE PARTITION FUNCTION myRangePF1(int) AS RANGE LEFT FOR VALUES (1,100,1000);,54/38,示例,例2在int列上創(chuàng)建右側(cè)分區(qū)函數(shù)。 CREATE PARTITION FUNCTION myRangePF2(int) AS RANGE RIGHT FOR VALUES (1, 100, 1000),55/38,示例,例3在datetime列上創(chuàng)建右側(cè)分區(qū)函數(shù)。將表分成12個分區(qū),每個分區(qū)對應一個月的

16、值 CREATE PARTITION FUNCTION myDateRangePF1(datetime) AS RANGE RIGHT FOR VALUES ( 20110201, 20110301, 20110401, 20110501, 20110601, 20110701, 20110801, 20110901, 20111001, 20111101, 20111201);,56/38,示例,例3在字符列上創(chuàng)建右側(cè)分區(qū)函數(shù)。下列分區(qū)函數(shù)將表分為四個分區(qū)。 CREATE PARTITION FUNCTION myRangePF3(char(20)) AS RANGE RIGHT FOR V

17、ALUES (EX, RXE, XR);,57/38,2. 創(chuàng)建分區(qū)方案,CREATE PARTITION SCHEME partition_scheme_name AS PARTITION partition_function_name ALL TO ( file_group_name | PRIMARY ,...n ) ; ,58/38,示例,例4.先創(chuàng)建一個分區(qū)函數(shù),該函數(shù)將表分為四個分區(qū)。然后創(chuàng)建一個分區(qū)方案,在其中指定擁有這四個分區(qū)中每一個分區(qū)的文件組 CREATE PARTITION FUNCTION myRangePF1(int) AS RANGE LEFT FOR

18、VALUES (1, 100, 1000); GO CREATE PARTITION SCHEME myRangePS1 AS PARTITION myRangePF1 TO (test1fg, test2fg, test3fg, test4fg);,59/38,例4的分區(qū)情況,在某表上對分區(qū)依據(jù)列col1使用分區(qū)函數(shù)myRangePF1后,對該表的分區(qū)進行分配的情況:,60/38,示例,例5. 創(chuàng)建將多個分區(qū)映射到同一個文件組的分區(qū)方案。如果要將所有分區(qū)都映射到同一個文件組,可使用ALL關鍵字。但如果是將多個(不是全部)分區(qū)映射到同一個文件組,則必須分別列出文件組名稱 CREATE PART

19、ITION FUNCTION myRangePF2(int) AS RANGE LEFT FOR VALUES (1, 100, 1000); GO CREATE PARTITION SCHEME myRangePS2 AS PARTITION myRangePF2 TO ( test1fg, test1fg, test1fg, test2fg ),61/38,例5分區(qū)情況,在某表上對分區(qū)依據(jù)列col1使用分區(qū)函數(shù)myRangePF2后,對該表的分區(qū)進行分配的情況,62/38,示例,例6. 創(chuàng)建將所有分區(qū)映射到同一個文件組的分區(qū)方案。 CREATE PARTITION FUNCTION myR

20、angePF3(int) AS RANGE LEFT FOR VALUES (1, 100, 1000); GO CREATE PARTITION SCHEME myRangePS3 AS PARTITION myRangePF3 ALL TO ( test1fg ),63/38,示例,例7.創(chuàng)建指定“NEXT USED”文件組的分區(qū)方案。本示例所創(chuàng)建的分區(qū)方案列出的文件組數(shù)超過了關聯(lián)的分區(qū)函數(shù)所創(chuàng)建的分區(qū)數(shù)。 CREATE PARTITION FUNCTION myRangePF4(int) AS RANGE LEFT FOR VALUES (1, 100, 1000); GO CREATE

21、 PARTITION SCHEME myRangePS4 AS PARTITION myRangePF4 TO (test1fg, test2fg, test3fg, test4fg, test5fg) 執(zhí)行該語句時系統(tǒng)返回以下消息: 分區(qū)方案myRangePS4已成功創(chuàng)建。test5fg在分區(qū)方案myRangePS4中標記為下次使用的文件組。,64/38,示例,例8. 本示例首先創(chuàng)建一個分區(qū)函數(shù),將數(shù)據(jù)分為四個分區(qū)。然后創(chuàng)建一個分區(qū)方案,最后創(chuàng)建使用該分區(qū)方案的表。本示例假定數(shù)據(jù)庫中已經(jīng)存在文件組。 CREATE PARTITION FUNCTION myRangePF1(int) AS R

22、ANGE LEFT FOR VALUES (1, 100, 1000); GO CREATE PARTITION SCHEME myRangePS1 AS PARTITION myRangePF1 TO (test1fg, test2fg, test3fg, test4fg); GO CREATE TABLE PartitionTable ( col1 int, col2 char(10) ) ON myRangePS1 (col1);,65/38,第6章 數(shù)據(jù)操作語言,6.1 數(shù)據(jù)查詢語句 6.2 數(shù)據(jù)更改功能,,,66,6.1 數(shù)據(jù)查詢語句,6.1.1 查詢語句基本結(jié)構(gòu) 6.1.2 單表查

23、詢 6.1.3 多表連接查詢 6.1.4 使用TOP限制結(jié)果集 6.1.5 將查詢結(jié)果保存到新表中,67/130,6.1.1 查詢語句基本結(jié)構(gòu),SELECT -- 需要哪些列 FROM -- 來自于哪些表 WHERE -- 根據(jù)什么條件 GROUP BY HAVING ORDER BY ,68/130,部分能夠包含的內(nèi)容,SELECT ALL | DISTINCT TOP expression PERCENT WITH TIES ::= * | table_name | view_name | table_alias .* | table_name |

24、view_name | table_alias . column_name | $IDENTITY | expression AS column_alias | column_alias = expression ,...n ,69/130,6.1.2 單表查詢,1.選擇表中若干列 2.選擇表中的若干元組 3.對查詢結(jié)果排序 4.使用聚合函數(shù)統(tǒng)計數(shù)據(jù) 5.對數(shù)據(jù)進行分組統(tǒng)計,70/130,1.選擇表中若干列:查詢指定列,在SELECT子句的中指定要查詢的屬性。 例1. 查詢?nèi)w學生的學號與姓名。 SELECT Sno,Sname FROM Student,71/1

25、30,示例,例2.查詢?nèi)w學生的姓名、學號和所在系。 SELECT Sname, Sno, Dept FROM Student 說明:查詢列表中的列順序與表中列定義的順序無關。,72/130,查詢?nèi)苛?如果要查詢表中的全部列,可以使用兩種方法: 在中列出所有的列名; 如果列的顯示順序與其在表中定義的順序相同,則可以簡單地在中寫星號“*”。,73/130,示例,例3 查詢?nèi)w學生的詳細記錄。 SELECT Sno, Sname, Sex, Sage, Dept FROM Student 等價于: SELECT * FROM Student,74/130,查詢經(jīng)過計算的列,SELECT子句中

26、的可以是表中存在的屬性列,也可以是表達式、常量或者函數(shù)。 例4 查詢?nèi)w學生的姓名及其出生年份。 SELECT Sname, year(getdate()) - year(Birthdate) FROM Student getdate():得到系統(tǒng)的當前日期和時間 year():得到日期數(shù)據(jù)中年的部分,75/130,示例,例5. 含字符串常量的列。 SELECT Sname, 出生年份, year(getdate()) FROM Student,,76/130,指定列別名, 列名 | 表達式 AS 列別名 或 列別名 列名 | 表達式 例: SELECT Sname, year(get

27、date()) - year(Birthdate) AS 年齡 FROM Student,77/130,指定列別名后的查詢結(jié)果,,SELECT Sname, year(getdate()) - year(Birthdate) AS 年齡 FROM Student,78/130,用DISTINCT去掉結(jié)果中的重復行,SELECT DISTINCT Sno FROM SC,,,Sno,DISTINCT Sno,79/130,注意,SELECT語句不會自動去掉結(jié)果中的重復行,如果要求結(jié)果中不出現(xiàn)行,必須要明確地指出 DISTINCT是確保檢索后的每一行是唯一的,這種唯一性是相對于其他行來說的。,80

28、/130,2. 選擇表中的若干元組,查詢滿足條件的元組可通過 WHERE子句實現(xiàn)。,81/130,常用的查詢條件,82,(1)比較大小,例7查詢計算機系全體學生。 SELECT Sname FROM Student WHERE Dept = 計算機系 例8查詢所有年齡20歲以下的學生的姓名及年齡。 SELECT Sname, year(getdate()) - year(Birthdate) AS 年齡 FROM Student WHERE year(getdate())-year(Birth)<20,83/130,示例,例9.查詢成績不及格學生的學號。 SELECT DISTINCT Sn

29、o FROM SC WHERE Grade < 60,,84/130,(2)確定范圍,BETWEENAND NOT BETWEENAND 作用:查找屬性值在或不在指定范圍內(nèi)的元組。 說明: BETWEEN后是范圍的下限(低值) AND后是范圍的上限(高值),85/130,示例,例10查詢考試成績在8090之間的學生學號、課程號和成績。,SELECT Sno, Cno, Grade FROM SC WHERE Grade BETWEEN 80 AND 90,等價于: SELECT Sno, Cno, Grade FROM SC WHERE Grade =80 AND Grade <=90,86/

30、130,示例,例11查詢考試成績不在8090之間的學生學號、課程號和成績。,SELECT Sno, Cno, Grade FROM SC WHERE Grade NOT BETWEEN 80 AND 90,等價于: SELECT Sno, Cno, Grade FROM SC WHERE Grade 90,87/130,示例:日期比較,例12. 設有圖書表(titles),其中包含書號(title_id)、類型(type)、價格(price)和出版日期(pubdate)列,查詢1991年6月出版的圖書信息: SELECT title_id, type, price, pubdate FROM

31、titles WHERE pubdate BETWEEN 1991/6/1 AND 1991/6/30,88/130,(3)確定集合(IN),作用:用來查找屬性值屬于指定集合的元組。 格式: 列名 NOT IN (常量1, 常量2, ),89/130,示例,SELECT Sname, Sex FROM Student WHERE Dept IN( 信息管理系, 通信工程系, 計算機系),例13查詢信息管理系、通信工程系和計算機系學生的姓名和性別。,等價于: SELECT Sname, Sex FROM Student WHERE Dept 信息管理系, OR Dept 通信工程系,

32、 OR Dept 計算機系,90/130,示例,例14.查詢信息管理系、通信工程系和計算機系三個系之外的其他系學生的姓名和性別。 SELECT Sname, Sex FROM Student WHERE Dept NOT IN ( 信息管理系, 通信工程系, 計算機系) 等價于: SELECT Sname, Sex FROM Student WHERE Dept!= 信息管理系 AND Dept!= 通信工程系 AND Dept!= 計算機系,91/130,(4)字符串匹配(LIKE),列名 NOT LIKE ESCAPE 匹配串中可包含如下通配符: %(百分號):匹配0個或多個字符。 _(下

33、劃線):匹配一個字符。 :匹配方括號中的任何一個字符。 :不匹配方括號中的任何一個字符。 若要比較的字符是連續(xù)的,則可以用連字符“-”表達,例如,要匹配b、c、d、e中的任何一個字符,則可以表示為:b-e,92/130,示例,例15.查詢姓“張”的學生詳細信息。 SELECT * FROM Student WHERE Sname LIKE 張%,93/130,示例,例16.查詢姓“張”、姓“李”和姓“劉”的學生的詳細信息。 SELECT * FROM Student WHERE Sname LIKE 張李劉%,94/130,示例,例17.查詢名字的第2個字為“小”或“大”的學生的姓名和學號。

34、 SELECT Sname, Sno FROM Student WHERE Sname LIKE _小大% 例18查詢所有不姓“劉”的學生姓名。 SELECT Sname FROM Student WHERE Sname NOT LIKE 劉%,95/130,示例,例19.在Student表中查詢學號的最后一位不是2、3、5的學生信息。 SELECT * FROM Student WHERE Sno LIKE %235,96/130,轉(zhuǎn)義字符,如果要查找的字符串正好含有通配符,比如下劃線或百分號,就需要用ESCAPE來說明。 ESCAPE 轉(zhuǎn)義字符 其中“轉(zhuǎn)義字符”是任何一個有效的字符,

35、在匹配串中也包含這個字符,表明位于該字符后面的那個字符將被視為普通字符,而不是通配符。,97/130,示例,查找field1字段中包含字符串“30%”的記錄: WHERE field1 LIKE %30!%% ESCAPE ! 查找field1字段中包含下劃線(_)的記錄: WHERE field1 LIKE %!_% ESCAPE !,98/130,(5)涉及空值的查詢,空值是未確定的值或其值尚不知道。 例如,學生選課,在開學初學生只有選課記錄,沒有修課成績,這時成績成績一項的值就是空值。 判斷列取值為空的語句格式為: 列名IS NULL 判斷列取值不為空的語句格式為: 列名 IS NOT

36、NULL,99/130,示例,例20.查詢還沒有考試的學生的學號和相應的課程號。 SELECT Sno, Cno FROM SC WHERE Grade IS NULL,100/130,注意,空值不是一個確定的值,所以不可以用等于或不等于來比較或衡量; 空值只能說是空值(IS NULL)或不是空值(IS NOT NULL)。,101/130,(6)多重條件查詢,當需要多個查詢條件時,可以在WHERE子句中使用邏輯運算符AND和OR來組成多條件查詢。 例21.查詢計算機系男生的姓名。 SELECT Sname FROM Student WHERE Dept = 計算機系 AND Sex =

37、男,102/130,示例,例22.查詢C002和C003課程中考試成績在8090的學生的學號、課程號和成績。 SELECT Sno, Cno, Grade FROM SC WHERE Cno IN( C002, C003) AND Grade BETWEEN 80 AND 90 注:OR的優(yōu)先級小于AND,要改變運算的順序可以通過加括號的方式實現(xiàn)。 SELECT Sno, Cno, Grade FROM SC WHERE (Cno = C001 OR Cno = C002) AND Grade BETWEEN 80 AND 90,103/130,3. 對查詢結(jié)果排序,可用ORDER B

38、Y子句對查詢結(jié)果進行排序。 ORDER BY ASC | DESC , 說明:按進行升序(ASC)或降序(DESC)排序。 當用多個列排序時,這些列在該子句中出現(xiàn)的順序決定了對結(jié)果集進行排序的方式。,104/130,示例,例23.查詢修了“C002”課程的學生的學號及成績,查詢結(jié)果按成績降序排列。 SELECT Sno, Grade FROM SC WHERE Cno = C002 ORDER BY Grade DESC,105/130,示例,例24.查詢?nèi)w學生詳細信息,結(jié)果按系名升序排列,同一個系的學生按出生日期降序排列。 SELECT * FROM Student ORDER BY

39、 Dept ASC, Birthdate DESC,106/130,例24執(zhí)行結(jié)果,,ORDER BY Dept, Birthdate DESC,107/130,4使用聚合函數(shù)匯總數(shù)據(jù),也稱為集合函數(shù)或聚合函數(shù), 其作用是對一組值進行計算并返回一個統(tǒng)計結(jié)果。,108/130,聚合函數(shù),COUNT(*):統(tǒng)計表中元組的個數(shù)。 COUNT(DISTINCT ):統(tǒng)計列值個數(shù) SUM():計算列值的和值(必須是數(shù)值型列)。 AVG():計算列值的平均值(必須是數(shù)值型列)。 MAX():得到列值的最大值。 MIN():得到列值的最小值。 除COUNT(*)外,其他函數(shù)在計算過程中均忽略NULL值。,1

40、09/130,示例,例25. 統(tǒng)計學生總?cè)藬?shù)。 SELECT COUNT(*) FROM Student,,10,110/130,示例,例26.統(tǒng)計選修了課程的學生人數(shù)。 SELECT COUNT(DISTINCT Sno) FROM SC,,4,111/130,示例,例. 計算學號為“0811101”的學生的考試總成績。 SELECT SUM(Grade) FROM SC WHERE Sno = 0811101,,322,112/130,示例,例28.計算“0831103”學生的平均成績。 SELECT AVG(Grade) FROM SC WHERE Sno = 0831103,,71

41、,113/130,示例,例28.查詢“C001”課程考試成績的最高分和最低分。 SELECT MAX(Grade) 最高分, MIN(Grade) 最低分 FROM SC WHERE Cno = C001,,96,50,,114/130,注意,聚合函數(shù)不能出現(xiàn)在WHERE子句中。 例如,查詢學分最高的課程名,如下寫法是錯誤的: SELECT Cname FROM Course WHERE Credit = MAX(Credit),115/130,5對數(shù)據(jù)進行分組統(tǒng)計,作用:可以控制計算的級別:對全表還是對一組。 目的:細化聚合函數(shù)的作用對象。 分組語句的一般形式: GROUP BY HAVI

42、NG ,116/130,使用GROUP BY子句,例29.統(tǒng)計每門課程的選課人數(shù),列出課程號和選課人數(shù)。 SELECT Cno, COUNT(Sno) FROM SC GROUP BY Cno 對查詢結(jié)果按Cno的值分組,所有具有相同Cno值的元組為一組,然后再對每一組使用COUNT計算,求出每組的學生人數(shù)。,117/130,示例,例30.統(tǒng)計每個學生的選課門數(shù)和平均成績。 SELECT Sno 學號, COUNT(*) 選課門數(shù), AVG(Grade) 平均成績 FROM SC GROUP BY Sno,118/130,注意,GROUP BY子句中的分組依據(jù)列必須是表中存在的列名,不能使用

43、AS子句指派的列別名。 帶有GROUP BY 子句的SELECT語句的查詢列表中只能出現(xiàn)分組依據(jù)列和統(tǒng)計函數(shù),因為分組后每個組只返回一行結(jié)果。,119/130,示例,例31. 帶WHERE子句的分組。統(tǒng)計每個系的女生人數(shù)。 SELECT Dept, Count(*) 女生人數(shù) FROM Student WHERE Sex = 女 GROUP BY Dept,120/130,示例,例32 按多個列分組。統(tǒng)計每個系的男生人數(shù)和女生人數(shù)以及男生的最大年齡和女生的最大年齡。結(jié)果按系名的升序排序。 SELECT Dept, Sex, Count(*) 人數(shù), Max(Sage) 最大年齡 FROM S

44、tudent GROUP BY Dept, Sex ORDER BY Dept,121/130,使用HAVING子句,HAVING用于對分組自身進行限制,它有點象WHERE子句,但它用于組而不是對單個記錄。,122/130,示例,例33. 查詢選課門數(shù)超過3門的學生的學號和選課門數(shù)。 SELECT Sno, Count(*) 選課門數(shù) FROM SC GROUP BY Sno HAVING COUNT(*) 3 處理過程為:先執(zhí)行GROUP BY子句對SC表數(shù)據(jù)按Sno進行分組,然后再用統(tǒng)計函數(shù)COUNT分別對每一組進行統(tǒng)計,最后篩選出統(tǒng)計結(jié)果滿足大于3的組。,123/130,示例,例34.

45、查詢選課門數(shù)大于等于4門的學生的平均成績和選課門數(shù)。 SELECT Sno, AVG(Grade) 平均成績, COUNT(*) 選課門數(shù) FROM SC GROUP BY Sno HAVING COUNT(*) = 4,124/130,一些說明,WHERE子句用來篩選FROM子句中指定的數(shù)據(jù)源所產(chǎn)生的行數(shù)據(jù)。 GROUP BY子句用來對經(jīng)WHERE子句篩選后的結(jié)果數(shù)據(jù)進行分組。 HAVING子句用來對分組后的統(tǒng)計結(jié)果再進行篩選。,125/130,一些說明,可以在分組操作之前應用的篩選條件,在WHERE子句中指定更有效。 在HAVING子句中指定的篩選條件應該是那些必須在執(zhí)行分組操作之后應

46、用的篩選條件。 將所有應該在分組之前進行的篩選條件放在WHERE子句中而不是HAVING子句中。,126/130,示例,例35. 查詢計算機系和信息管理系每個系的學生人數(shù)。 SELECT Dept, COUNT(*) FROM Student GROUP BY Dept HAVING Dept in (計算機系, 信息管理系) SELECT Dept, COUNT (*) FROM Student WHERE Dept in ( 計算機系, 信息管理系) GROUP BY Dept,,X,127/130,示例,例36查詢每個系的男生人數(shù)。 SELECT Dept, COUNT(*) F

47、ROM Student WHERE Sex = 男 GROUP BY Dept 該查詢語句不能寫成: SELECT Dept, COUNT(*) FROM Student GROUP BY Dept HAVING Sex = 男,128/130,6.1.3 多表連接查詢,若一個查詢同時涉及兩個或兩個以上的表,則稱之為連接查詢。 連接查詢是關系數(shù)據(jù)庫中最主要的查詢,主要包括: 內(nèi)連接 外連接:左外連接、右外連接,129/130,內(nèi)連接,是一種最常用的連接類型。使用內(nèi)連接時,如果兩個表的相關字段滿足連接條件,則從這兩個表中提取數(shù)據(jù)并組合成新的記錄。 在非ANSI標準的實現(xiàn)中,連接操作是在WHE

48、RE子句中執(zhí)行的theta連接 在ANSI SQL-92中,連接是在JOIN子句中執(zhí)行的ANSI連接。 我們介紹ANSI方式的連接格式: FROM 表1 INNER JOIN 表2 ON ,130/130,連接基礎知識,連接查詢中用于連接兩個表的條件稱為連接條件或連接謂詞。 一般格式為: =,必須是可比列,,,131/130,執(zhí)行連接操作的大致過程,首先取表1中的第1個元組,然后從頭開始掃描表2,逐一查找滿足連接條件的元組, 找到后就將表1中的第1個元組與該元組拼接起來,形成結(jié)果表中的一個元組。 表2全部查找完畢后,再取表1中的第2個元組,然后再從頭開始掃描表2, 重復這個過程,直到表1中的全

49、部元組都處理完畢為止。,132/130,示例,SELECT * FROM Student INNER JOIN SC ON Student.Sno=SC.Sno,133/130,去掉重復列,SELECT Student.Sno, Sname, Sex, Sage, Dept, Cno, Grade FROM Student JOIN SC ON Student.Sno = SC.Sno,134/130,示例,例38. 查詢計算機系學生的修課情況,要求列出學生的名字、所修課的課程號和成績。 SELECT Sname, Cno, Grade FROM Student JOIN SC ON S

50、tudent.Sno = SC.Sno WHERE Dept = 計算機系,135/130,指定列別名, AS 為表指定別名可以簡化表的書寫。 SELECT Sname, Cno, Grade FROM Student S JOIN SC ON S.Sno = SC.Sno WHERE Dept = 計算機系 注意:當為表指定了別名時,在查詢語句中的其他地方,所有用到表名的地方都要使用別名,而不能再使用原表名。,136/130,示例,例39. 查詢“信息管理系”修了“計算機文化學” 的學生姓名和成績。 SELECT Sname, Grade FROM Student s JOIN SC ON

51、 s.Sno = SC. Sno JOIN Course c ON c.Cno = SC.Cno WHERE Dept = 信息管理系 AND Cname = 計算機文化學,137/130,示例,例40. 查詢所有選修了Java課程的學生情況,列出學生姓名和所在系。 SELECT Sname, Dept FROM Student S JOIN SC ON S.Sno = SC. Sno JOIN Course C ON C.Cno = SC.cno WHERE Cname = Java,138/130,示例,例41.有分組的多表連接查詢。統(tǒng)計每個系的學生的考試平均成績。 SELECT Dept

52、, AVG(grade) as AverageGrade FROM student S JOIN SC ON S.Sno = SC.Sno GROUP BY Dept,139/130,示例,例42. 有分組和行選擇條件的多表連接查詢。統(tǒng)計計算機系學生每門課程的選課人數(shù)、平均成績、最高成績和最低成績。 SELECT Cno, COUNT(*) AS Total, AVG(Grade) as AvgGrade, MAX(Grade) as MaxGrade, MIN(Grade) as MinGrade FROM Student S JOIN SC ON S.Sno = SC.Sno

53、 WHERE Dept = 計算機系 GROUP BY Cno,140/130,自連接,是特殊的內(nèi)連接。 相互連接的表物理上為同一張表。 必須為兩個表取別名,使之在邏輯上成為兩個表。 FROM 表1 AS T1 -- 在內(nèi)存中生成“T1” JOIN 表1 AS T2 -- 在內(nèi)存中生成“T2”,141/130,示例,例43. 查詢與劉晨在同一個系學習的學生的姓名和所在的系。 SELECT S2.Sname, S2.Dept FROM Student S1 JOIN Student S2 ON S1.Dept = S2.Dept WHERE S1.Sname = 劉晨 AND S2.Sname

54、!= 劉晨,142/130,示例,例44. 查詢與“數(shù)據(jù)結(jié)構(gòu)”在同一個學期開設的課程的課程名和開課學期 SELECT C1.Cname, C1.Semester FROM Course C1 JOIN Course C2 ON C1.Semester = C2.Semester WHERE C2.Cname = 數(shù)據(jù)結(jié)構(gòu),143/130,示例,例45. 查詢至少被兩個學生選的課程的課程號。 SELECT DISTINCT a.Cno FROM SC a JOIN SC b ON a.Cno = b.Cno AND a.Sno != b.Sno 或者: SELECT Cno FROM SC GR

55、OUP BY Cno HAVING COUNT(*) 1,144/130,外連接,外連接會返回FROM子句中提到的至少一個表的所有行,只要這些行符合任何WHERE或HAVING搜索條件。 左外連接 FROM 表1 LEFT OUTER JOIN 表2 ON 右外連接 FROM 表1 RIGHT OUTER JOIN 表2 ON ,145/130,內(nèi)連接與外連接示意圖,A與B的左外連接結(jié)果: A + C,A與B的右外連接結(jié)果: B+ C,A與B的內(nèi)連接結(jié)果: C,146/130,示例,例46 查詢?nèi)w學生的選課情況,包括選修了課程的學生和沒有選修課程的學生。 SELECT Stu

56、dent.Sno, Sname, Cno, Grade FROM Student LEFT JOIN SC ON Student.Sno = SC.Sno 或: SELECT Student.Sno, Sname, Cno, Grade FROM SC RIGHT JOIN Student ON Student.Sno = SC.Sno,147/130,例46執(zhí)行部分結(jié)果示例,148/130,示例,例47. 查詢沒人選的課程的課程名。 SELECT Cname FROM Course C LEFT JOIN SC ON C.Cno = SC.Cno WHERE SC.Cno IS NU

57、LL,149/130,示例,例48. 查詢計算機系沒有選課的學生,列出學生姓名和性別。 SELECT Sname,Dept,Cno,grade FROM Student S LEFT JOIN SC ON S.Sno = SC.Sno WHERE Dept = 計算機系 AND SC.Sno IS NULL,150/130,示例,例49. 統(tǒng)計計算機系每個學生的選課門數(shù),包括沒有選課的學生。 SELECT S.Sno AS 學號, COUNT(SC.Cno) AS 選課門數(shù) FROM Student S LEFT JOIN SC ON S.Sno = SC.Sno WHERE Dept =

58、計算機系 GROUP BY S.Sno,151/130,示例,例50. 查詢信息管理系選課門數(shù)少于3門的學生的學號和選課門數(shù),包括沒有選課的學生。查詢結(jié)果按選課門數(shù)遞增排序。 SELECT S.Sno AS 學號,COUNT(SC.Cno) AS 門數(shù) FROM Student S LEFT JOIN SC ON S.Sno = SC.Sno WHERE Dept = 信息管理系 GROUP BY S.Sno HAVING COUNT(SC.Cno) < 3 ORDER BY COUNT(SC.Cno) ASC,152/130,說明,當外連接與內(nèi)連接混合使用時,對側(cè)的概念的理解就非常重要。 所

59、有查詢語句中JOIN左側(cè)或之前的所有表只作為一個表(這個表有可能是多個連接操作產(chǎn)生的結(jié)果表),同樣,所有查詢語句中JOIN右側(cè)或之后的表也只作為一個表。,153/130,示例:設有三張表,154/130,查詢1,查詢?nèi)抗痰腣endorName及其在Vendors和VendorAddress兩個表中的VendorID。 SELECT v.VendorID, v.VendorName, va.VendorID FROM Vendors v LEFT OUTER JOIN VendorAddress va ON v.VendorID = va.VendorID,155/130,查詢2,查詢?nèi)?/p>

60、供應商的VendorName及其Address。由于并不要求返回全部的地址,因此對Address表可以采用內(nèi)連接 SELECT v.VendorName, a.Address FROM Vendors v LEFT OUTER JOIN VendorAddress va ON v.VendorID = va.VendorID JOIN Address a ON va.AddressID = a.AddressID,丟失了Vendor3,156/130,修改查詢2,(1)添加一個外連接操作 SELECT v.VendorName, a.Address FROM Vendors v LEFT OU

61、TER JOIN VendorAddress va ON v.VendorID = va.VendorID LEFT OUTER JOIN Address a ON va.AddressID = a.AddressID (2)改變連接操作順序 SELECT v.VendorName, a.Address FROM VendorAddress va JOIN Address a ON va.AddressID = a.AddressID RIGHT OUTER JOIN Vendors v ON v.VendorID = va.VendorID,157/130,4全外連接,若要保留兩個表中都不滿

62、足連接條件的數(shù)據(jù)行,則可使用完全外部連接(簡稱全外連接)。 SQL Server 提供的全外連接運算符為: FULL OUTER JOIN 該操作的結(jié)果將包含兩個表中的所有行,不論另一個表中是否有匹配的值。,158/130,實例,select * from T1 full join T2 on T1.T1_C11 = T2.T2_C11,,159/130,6.1.4 使用TOP限制結(jié)果集行數(shù),TOP (expression) percent WITH TIES expression :指定返回行數(shù)的數(shù)值表達式。 TOP n percnet:取查詢結(jié)果的前n%行。 WITH TIES:包括并列的

63、結(jié)果。 TOP謂詞寫在SELECT單詞的后邊,160/130,示例,例52.查詢考試成績最高的三個成績,列出學號、課程號和成績。 SELECT TOP 3 Sno, Cno, Grade FROM SC ORDER BY Grade DESC,161/130,示例,例53. 查詢Java考試成績最高的前三名的學生的姓名、所在系和VB考試成績。 SELECT TOP 3 WITH TIES Sname, Dept, Grade FROM Student S JOIN SC on S.Sno = SC.Sno JOIN Course C ON C.Cno = SC.Cno WHERE Cname

64、= Java ORDER BY Grade DESC 注意:如果在TOP子句中使用了WITH TIES謂詞,則要求必須使用ORDER BY子句對查詢結(jié)果進行排序,162/130,示例,例54. 查詢選課人數(shù)最少的兩門課程(不包括沒有人選的課程),列出課程號和選課人數(shù)。 SELECT TOP 2 WITH TIES Cno, COUNT(*) 選課人數(shù) FROM SC GROUP BY Cno ORDER BY COUNT(Cno) ASC,163/130,示例,例55. 查詢計算機系選課門數(shù)超過2門的學生中,考試平均成績最高的前2名(包括并列的情況)學生的學號、選課門數(shù)和平均成績。 SELEC

65、T TOP 2 WITH TIES S.Sno, COUNT(*) 選課門數(shù),AVG(Grade) 平均成績 FROM Student S JOIN SC ON S.Sno = SC.Sno WHERE Dept = 計算機系 GROUP BY S.sno HAVING COUNT(*) 2 ORDER BY AVG(Grade) DESC,164/130,6.1.5 將查詢結(jié)果保存到新表中,如果希望將查詢結(jié)果保存到一個表中,則可以通過在SELECT語句中使用INTO子句實現(xiàn)。 包含INTO子句的SELECT語句的簡單語法格式可描述為: SELECT 查詢列表序列 INTO FROM 數(shù)據(jù)源

66、 -- 其他行過濾、分組等語句,165/130,語句功能,根據(jù)查詢列表序列的內(nèi)容創(chuàng)建一個新表,新表中各列的列名就是查詢結(jié)果中顯示的列標題,列的數(shù)據(jù)類型是這些查詢列在原表中定義的數(shù)據(jù)類型。 執(zhí)行查詢語句并將查詢的結(jié)果按列對應順序保存到該新表中。,166/130,局部臨時表和全局臨時表,局部臨時表在表名前加一個#來標識。局部臨時表的生存期為創(chuàng)建此局部臨時表的連接的生存期,它只能在創(chuàng)建此局部臨時表的當前連接中使用; 全局臨時表在表名前加兩個#來標識。全局臨時表的生存期為創(chuàng)建全局臨時表的連接的生存期,并且在生存期內(nèi)可以被所有的連接使用。,167/130,示例,例56將計算機系的學生信息保存到#ComputerStudent局部臨時表中。 SELECT Sno, Sname, Sex, Sage INTO #ComputerStudent FROM Student WHERE Dept = 計算機系,168/130,示例,例57將選了Java課程的學生的學號及成績存入永久表Java_Grade中。 SELECT Sno, Grade INTO Java_Grade FROM SC JOIN

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

相關資源

更多
正為您匹配相似的精品文檔
關于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!