SQL非常全面的入門教程.doc
《SQL非常全面的入門教程.doc》由會(huì)員分享,可在線閱讀,更多相關(guān)《SQL非常全面的入門教程.doc(83頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。
1、SQL語(yǔ)言快速入門 入門教程 2 SQL語(yǔ)言快速入門之一 2 SQL語(yǔ)言快速入門之二 3 SQL語(yǔ)言快速入門之三 6 基礎(chǔ)教程 11 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))1 11 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))2 14 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))3 17 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))4 20 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))5 25 SQL數(shù)據(jù)操作基礎(chǔ)(中級(jí)) 27 SQL數(shù)據(jù)操作基礎(chǔ)(中級(jí))1 27 SQL數(shù)據(jù)操作基礎(chǔ)(中級(jí))2 29 SQL數(shù)據(jù)操作基礎(chǔ)(中級(jí))3 32 SQL數(shù)據(jù)操作基礎(chǔ)(中級(jí))4 36 SQL數(shù)據(jù)操作基礎(chǔ)(中級(jí))5 39 全面接觸SQL 45 全面接
2、觸SQL語(yǔ)法(1) 45 全面接觸SQL語(yǔ)法(2) 46 全面接觸SQL語(yǔ)法(3) 48 全面接觸SQL語(yǔ)法(4) 49 全面接觸SQL語(yǔ)法(5) 51 全面接觸SQL語(yǔ)法(6) 54 全面接觸SQL語(yǔ)法(7) 55 SQL語(yǔ)法詳解 59 主要SQL語(yǔ)句詳解(1) 59 主要SQL語(yǔ)句詳解(2) 63 SQL語(yǔ)法參考手冊(cè) 67 SQL實(shí)踐 71 SQL實(shí)踐(1) 71 SQL實(shí)踐(2) 75 Sql連接查詢 80 入門教程 SQL語(yǔ)言快速入門之一 SQL是英文Structured Query Language的縮寫,意思為結(jié)構(gòu)化查詢語(yǔ)言。SQL語(yǔ)言
3、的主要功能就是同各種數(shù)據(jù)庫(kù)建立聯(lián)系,進(jìn)行溝通。按照ANSI(美國(guó)國(guó)家標(biāo)準(zhǔn)協(xié)會(huì))的規(guī)定,SQL被作為關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)的標(biāo)準(zhǔn)語(yǔ)言。SQL語(yǔ)句可以用來(lái)執(zhí)行各種各樣的操作,例如更新數(shù)據(jù)庫(kù)中的數(shù)據(jù),從數(shù)據(jù)庫(kù)中提取數(shù)據(jù)等。目前,絕大多數(shù)流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),如Oracle, Sybase, Microsoft SQL Server, Access等都采用了SQL語(yǔ)言標(biāo)準(zhǔn)。雖然很多數(shù)據(jù)庫(kù)都對(duì)SQL語(yǔ)句進(jìn)行了再開(kāi)發(fā)和擴(kuò)展,但是包括Select, Insert, Update, Delete, Create,以及Drop在內(nèi)的標(biāo)準(zhǔn)的SQL命令仍然可以被用來(lái)完成幾乎所有的數(shù)據(jù)庫(kù)操作。下面,我們就來(lái)詳細(xì)介
4、紹一下SQL語(yǔ)言的基本知識(shí)。 數(shù)據(jù)庫(kù)表格 一個(gè)典型的關(guān)系型數(shù)據(jù)庫(kù)通常由一個(gè)或多個(gè)被稱作表格的對(duì)象組成。數(shù)據(jù)庫(kù)中的所有數(shù)據(jù)或信息都被保存在這些數(shù)據(jù)庫(kù)表格中。數(shù)據(jù)庫(kù)中的每一個(gè)表格都具有自己唯一的表格名稱,都是由行和列組成,其中每一列包括了該列名稱,數(shù)據(jù)類型,以及列的其它屬性等信息,而行則具體包含某一列的記錄或數(shù)據(jù)。以下,是一個(gè)名為天氣的數(shù)據(jù)庫(kù)表格的實(shí)例。 城市 最高氣溫 最低氣溫 北京 10 5 上海 15 8 天津 8 2 重慶 20 13 該表格中“城市”, “最高氣溫”和“最低氣溫”就是三個(gè)不同的列,而表格中的每一行則包含了具體的表格數(shù)據(jù)。
5、 數(shù)據(jù)查詢 在眾多的SQL命令中,select語(yǔ)句應(yīng)該算是使用最頻繁的。Select語(yǔ)句主要被用來(lái)對(duì)數(shù)據(jù)庫(kù)進(jìn)行查詢并返回符合用戶查詢標(biāo)準(zhǔn)的結(jié)果數(shù)據(jù)。Select語(yǔ)句的語(yǔ)法格式如下: select column1 [, column2,etc] from tablename [where condition]; ([]表示可選項(xiàng)) select語(yǔ)句中位于select關(guān)鍵詞之后的列名用來(lái)決定那些列將作為查詢結(jié)果返回。用戶可以按照自己的需要選擇任意列,還可以使用通配符“*”來(lái)設(shè)定返回表格中的所有列。 select語(yǔ)句中位于from關(guān)鍵詞之后的表格名稱用來(lái)決定將要進(jìn)行查詢操作的目標(biāo)表格。
6、 Select語(yǔ)句中的where可選從句用來(lái)規(guī)定哪些數(shù)據(jù)值或哪些行將被作為查詢結(jié)果返回或顯示。 在where條件從句中可以使用以下一些運(yùn)算符來(lái)設(shè)定查詢標(biāo)準(zhǔn): =等于 >大于 <小于 >=大于等于 <=小于等于 <>不等于 除了上面所提到的運(yùn)算符外,LIKE運(yùn)算符在where條件從句中也非常重要。LIKE運(yùn)算符的功能非常強(qiáng)大,通過(guò)使用LIKE運(yùn)算符可以設(shè)定只選擇與用戶規(guī)定格式相同的記錄。此外,我們還可以使用通配符“%”用來(lái)代替任何字符串。舉例如下: select firstname, lastname, city from employee where firstname
7、LIKE ‘E%’; (注意,字符串必須被包含在單括號(hào)內(nèi)) 上述SQL語(yǔ)句將會(huì)查詢所有名稱以E開(kāi)頭的姓名。或者,通過(guò)如下語(yǔ)句: select * from employee where firstname = ‘May’; 查詢所有名稱為May的行。 SQL語(yǔ)言快速入門之二 創(chuàng)建表格 SQL語(yǔ)言中的create table語(yǔ)句被用來(lái)建立新的數(shù)據(jù)庫(kù)表格。Create table語(yǔ)句的使用格式如下: create table tablename (column1 data type, column2 data type, column3 data type); 如果用戶希
8、望在建立新表格時(shí)規(guī)定列的限制條件,可以使用可選的條件選項(xiàng): create table tablename (column1 data type [constraint], column2 data type [constraint], column3 data type [constraint]); 舉例如下: create table employee (firstname varchar(15), lastname varchar(20), age number(3), address varchar(30), city varchar(20)); 簡(jiǎn)單來(lái)說(shuō),創(chuàng)建新
9、表格時(shí),在關(guān)鍵詞create table后面加入所要建立的表格的名稱,然后在括號(hào)內(nèi)順次設(shè)定各列的名稱,數(shù)據(jù)類型,以及可選的限制條件等。注意,所有的SQL語(yǔ)句在結(jié)尾處都要使用“;”符號(hào)。 使用SQL語(yǔ)句創(chuàng)建的數(shù)據(jù)庫(kù)表格和表格中列的名稱必須以字母開(kāi)頭,后面可以使用字母,數(shù)字或下劃線,名稱的長(zhǎng)度不能超過(guò)30個(gè)字符。注意,用戶在選擇表格名稱時(shí)不要使用SQL語(yǔ)言中的保留關(guān)鍵詞,如select, create, insert等,作為表格或列的名稱。 數(shù)據(jù)類型用來(lái)設(shè)定某一個(gè)具體列中數(shù)據(jù)的類型。例如,在姓名列中只能采用varchar或char的數(shù)據(jù)類型,而不能使用number的數(shù)據(jù)類型。 SQL語(yǔ)言中較
10、為常用的數(shù)據(jù)類型為: char(size):固定長(zhǎng)度字符串,其中括號(hào)中的size用來(lái)設(shè)定字符串的最大長(zhǎng)度。Char類型的最大長(zhǎng)度為255字節(jié)。 varchar(size):可變長(zhǎng)度字符串,最大長(zhǎng)度由size設(shè)定。 number(size):數(shù)字類型,其中數(shù)字的最大位數(shù)由size設(shè)定。 Date:日期類型。 number(size,d):數(shù)字類型,size決定該數(shù)字總的最大位數(shù),而d則用于設(shè)定該數(shù)字在小數(shù)點(diǎn)后的位數(shù)。 最后,在創(chuàng)建新表格時(shí)需要注意的一點(diǎn)就是表格中列的限制條件。所謂限制條件就是當(dāng)向特定列輸入數(shù)據(jù)時(shí)所必須遵守的規(guī)則。例如,unique這一限制條件要求某一列中不能存在兩個(gè)值
11、相同的記錄,所有記錄的值都必須是唯一的。除unique之外,較為常用的列的限制條件還包括not null和primary key等。Not null用來(lái)規(guī)定表格中某一列的值不能為空。Primary key則為表格中的所有記錄規(guī)定了唯一的標(biāo)識(shí)符。 向表格中插入數(shù)據(jù) SQL語(yǔ)言使用insert語(yǔ)句向數(shù)據(jù)庫(kù)表格中插入或添加新的數(shù)據(jù)行。Insert語(yǔ)句的使用格式如下: insert into tablename (first_column,...last_column) values (first_value,...last_value); 例如: insert into employe
12、e (firstname, lastname, age, address, city) values (‘Li’, ‘Ming’, 45, ‘No.77 Changan Road’, ‘Beijing”); 簡(jiǎn)單來(lái)說(shuō),當(dāng)向數(shù)據(jù)庫(kù)表格中添加新記錄時(shí),在關(guān)鍵詞insert into后面輸入所要添加的表格名稱,然后在括號(hào)中列出將要添加新值的列的名稱。最后,在關(guān)鍵詞values的后面按照前面輸入的列的順序?qū)?yīng)的輸入所有要添加的記錄值。 更新記錄 SQL語(yǔ)言使用update語(yǔ)句更新或修改滿足規(guī)定條件的現(xiàn)有記錄。Update語(yǔ)句的格式為: update tablename set colum
13、nname = newvalue [, nextcolumn = newvalue2...] where columnname OPERATOR value [and|or column OPERATOR value]; 例如: update employee set age = age+1 where first_name= ‘Mary’and last_name= ‘Williams’; 使用update語(yǔ)句時(shí),關(guān)鍵一點(diǎn)就是要設(shè)定好用于進(jìn)行判斷的where條件從句。 刪除記錄 SQL語(yǔ)言使用delete語(yǔ)句刪除數(shù)據(jù)庫(kù)表格中的行或記錄。Delete語(yǔ)句的格式為: delet
14、e from tablename where columnname OPERATOR value [and|or column OPERATOR value]; 例如: delete from employee where lastname = May; 簡(jiǎn)單來(lái)說(shuō),當(dāng)需要?jiǎng)h除某一行或某個(gè)記錄時(shí),在delete from關(guān)鍵詞之后輸入表格名稱,然后在where從句中設(shè)定刪除記錄的判斷條件。注意,如果用戶在使用delete語(yǔ)句時(shí)不設(shè)定where從句,則表格中的所有記錄將全部被刪除。 刪除數(shù)據(jù)庫(kù)表格 在SQL語(yǔ)言中使用drop table命令刪除某個(gè)表格以及該表格中的所有記錄。Drop
15、 table命令的使用格式為: drop table tablename; 例如: drop table employee; 如果用戶希望將某個(gè)數(shù)據(jù)庫(kù)表格完全刪除,只需要在drop table命令后輸入希望刪除的表格名稱即可。Drop table命令的作用與刪除表格中的所有記錄不同。刪除表格中的全部記錄之后,該表格仍然存在,而且表格中列的信息不會(huì)改變。而使用drop table命令則會(huì)將整個(gè)數(shù)據(jù)庫(kù)表格的所有信息全部刪除。 以上,我們對(duì)SQL語(yǔ)言主要的命令和語(yǔ)句進(jìn)行了較為詳細(xì)的介紹。應(yīng)該說(shuō)SQL語(yǔ)句的語(yǔ)法結(jié)構(gòu)和風(fēng)格還是相當(dāng)簡(jiǎn)單和直觀的,只要用戶結(jié)合實(shí)踐多加練習(xí),一定會(huì)在短期內(nèi)迅速掌握。
16、 SQL語(yǔ)言快速入門之三 我們?nèi)粘J褂肧QL語(yǔ)言的工作過(guò)程中,使用最多的還是從已經(jīng)建立好的數(shù)據(jù)庫(kù)中查詢信息。下面,我們就來(lái)詳細(xì)介紹一下如何使用SQL語(yǔ)言實(shí)現(xiàn)各種數(shù)據(jù)庫(kù)查詢操作。 SELECT…FROM 為方便講解,我們?cè)跀?shù)據(jù)庫(kù)中創(chuàng)建名為Store_Information的如下數(shù)據(jù)表。 Store_Information Store_Name Sales Date Los Angeles $1500 Jan-10-2000 San Diego $250 Jan-11-2000 Los Angeles $300 Jan-12-2000 Boston $700
17、 Jan-12-2000 SQL語(yǔ)言中用于數(shù)據(jù)庫(kù)查詢的最簡(jiǎn)單的命令就是SELECT…FROM,語(yǔ)法格式為: SELECT "column_name" FROM "table_name" 例如,如果我們希望查詢Store_Information數(shù)據(jù)表中所有的商店名稱時(shí),可以使用如下命令: SELECT store_name FROM Store_Information 查詢結(jié)果顯示為: Store_Name Los Angeles San Diego Los Angeles Boston 如果用戶希望一次查詢多個(gè)字段,可以將所要查詢的字段名稱依次加入SELECT關(guān)鍵字之后,
18、中間用“,”隔開(kāi)即可。 DISTINCT SELECT關(guān)鍵字支持用戶查詢數(shù)據(jù)表中指定字段的所有數(shù)據(jù),但是這樣有時(shí)就會(huì)不可避免的出現(xiàn)重復(fù)信息。如果用戶希望只查詢那些具有不同記錄值的信息的話,可以使用SQL語(yǔ)言的DISTINCT關(guān)鍵字。語(yǔ)法格式如下: SELECT DISTINCT "column_name" FROM "table_name" 例如,我們可以使用以下命令查詢Store_Information數(shù)據(jù)表具有不同記錄值的所有記錄。 SELECT DISTINCT Store_Name FROM Store_Information 查詢結(jié)果如下: Store_Name L
19、os Angeles San Diego Boston WHERE 除了選擇具有不同記錄值的記錄之外,有時(shí)我們可能還會(huì)需要根據(jù)某些條件對(duì)數(shù)據(jù)庫(kù)中的數(shù)據(jù)進(jìn)行查詢。例如,我們可能需要查詢Store_Information數(shù)據(jù)表中銷售額超過(guò)1000美圓的商店。為此,我們可以使用SQL語(yǔ)言的WHERE關(guān)鍵字設(shè)定查詢條件。語(yǔ)法格式如下: SELECT "column_name" FROM "table_name" WHERE "condition" 由此,我們可以使用如下命令查詢銷售額超過(guò)1000美圓的商店信息: SELECT store_name FROM Store_Informa
20、tion WHERE Sales > 1000 查詢結(jié)果顯示為: store_name Los Angeles 運(yùn)算函數(shù) 現(xiàn)在,我們已經(jīng)了解到在使用SQL語(yǔ)言進(jìn)行數(shù)據(jù)庫(kù)查詢操作時(shí)可以通過(guò)對(duì)數(shù)值的判斷設(shè)定靈活的查詢條件。為了增強(qiáng)對(duì)運(yùn)算的支持能力,SQL提供了眾多實(shí)用的運(yùn)算函數(shù)供廣大用戶使用。例如,我們可以直接在SQL命令中調(diào)用SUM或AVG這兩個(gè)分別用于計(jì)算總數(shù)和平均數(shù)的函數(shù)。語(yǔ)法格式如下: SELECT "function type"("column_name") FROM "table_name" 如果我們希望查詢Store_Information數(shù)據(jù)表中所有商店的總銷售額的
21、話,可以使用如下命令: SELECT SUM(Sales) FROM Store_Information 查詢結(jié)果顯示為: SUM(Sales) $2750 COUNT 除了SUM和AVG函數(shù)之外,COUNT函數(shù)是SQL語(yǔ)言中另一個(gè)較為常用的運(yùn)算函數(shù)。COUNT函數(shù)可以用來(lái)計(jì)算數(shù)據(jù)表中指定字段所包含的記錄數(shù)目。語(yǔ)法格式為: SELECT COUNT("column_name") FROM "table_name" 例如,如果我們希望查詢Store_Information數(shù)據(jù)表中的有關(guān)商店的記錄條數(shù)時(shí),可以使用如下命令: SELECT COUNT(store_name) F
22、ROM Store_Information 查詢結(jié)果顯示為: Count(store_name) 4 COUNT函數(shù)可以和DISTINCT關(guān)鍵字一起使用從而可以查詢數(shù)據(jù)表中指定字段中所有具有不同記錄值的記錄數(shù)目。例如,如果我們希望查詢Store_Information數(shù)據(jù)表中不同商店的數(shù)目時(shí),可以使用如下命令: SELECT COUNT(DISTINCT store_name) FROM Store_Information 查詢結(jié)果顯示為: Count(DISTINCT store_name) 3 GROUP BY 下面我們來(lái)進(jìn)一步看一下SQL語(yǔ)言中的集合函數(shù)。上文中,我
23、們?cè)褂肧UM函數(shù)計(jì)算所有商店的銷售總額,如果我們希望計(jì)算每一家商店各自的總銷售額時(shí)該怎么辦呢?要實(shí)現(xiàn)這一目的我們需要做兩件事:首先,我們需要查詢商店名稱和銷售額兩個(gè)字段;然后,我們使用SQL語(yǔ)言的GROUP BY命令將銷售額按照不同的商店進(jìn)行分組,從而計(jì)算出不同商店的銷售總額。GROUP BY命令的語(yǔ)法格式為: SELECT "column_name1", SUM("column_name2") FROM "table_name" GROUP BY "column_name1" 我們可以使用如下命令實(shí)現(xiàn)上述查詢目的: SELECT store_name, SUM(Sales) F
24、ROM Store_Information GROUP BY store_name 查詢結(jié)果顯示為: store_name SUM(Sales) Los Angeles $1800 San Diego $250 Boston $700 小注: GROUP BY關(guān)鍵字一般應(yīng)用于同時(shí)查詢多個(gè)字段并對(duì)字段進(jìn)行算術(shù)運(yùn)算的SQL命令中。 HAVING 用戶在使用SQL語(yǔ)言的過(guò)程中可能希望解決的另一個(gè)問(wèn)題就是對(duì)由sum或其它集合函數(shù)運(yùn)算結(jié)果的輸出進(jìn)行限制。例如,我們可能只希望看到Store_Information數(shù)據(jù)表中銷售總額超過(guò)1500美圓的商店的信息,這時(shí)我們就需要使用HAVIN
25、G從句。語(yǔ)法格式為: SELECT "column_name1", SUM("column_name2") FROM "table_name" GROUP BY "column_name1" HAVING (arithematic function condition) (GROUP BY從句可選) 由此,我們可以使用如下命令實(shí)現(xiàn)上述查詢目的: SELECT store_name, SUM(sales) FROM Store_Information GROUP BY store_name HAVING SUM(sales) > 1500 查詢結(jié)果顯示為: store_n
26、ame SUM(Sales) Los Angeles $1800 小注: SQL語(yǔ)言中設(shè)定集合函數(shù)的查詢條件時(shí)使用HAVING從句而不是WHERE從句。通常情況下,HAVING從句被放置在SQL命令的結(jié)尾處。 ALIAS 下面,我們重點(diǎn)介紹一下如何在SQL命令中設(shè)定別名。SQL語(yǔ)言中一般使用兩種類型的別名,分別為字段別名和數(shù)據(jù)表別名。 簡(jiǎn)單的說(shuō),使用字段別名可以幫助我們有效的組織查詢的輸出結(jié)果。例如,上文所列舉的多個(gè)實(shí)例中,當(dāng)我們計(jì)算商店銷售總額時(shí),顯示結(jié)果中就會(huì)出現(xiàn)SUM(sales)。雖然SUM(sales)并不會(huì)對(duì)我們理解查詢結(jié)果帶來(lái)不便,但是如果我們需要在查詢中使用多項(xiàng)復(fù)雜
27、運(yùn)算時(shí),顯示結(jié)果就不會(huì)這么直觀了。如果這時(shí)我們使用字段別名就會(huì)極大的提高查詢結(jié)果的可讀性。 對(duì)于數(shù)據(jù)表別名,我們可以通過(guò)將別名直接放置在FROM從句中數(shù)據(jù)表名稱的后面設(shè)定。數(shù)據(jù)表別名在我們下面將要講述的連接多個(gè)數(shù)據(jù)表進(jìn)行查詢的操作中極為有用。 字段和數(shù)據(jù)表別名的語(yǔ)法格式如下: SELECT "table_alias"."column_name1" "column_alias" FROM "table_name" "table_alias" 即別名都直接放置在各自對(duì)應(yīng)名稱的后面,中間用空格分開(kāi)。 以Store_Information數(shù)據(jù)表為例,我們可以在GROUP BY一節(jié)中所使用的
28、SQL命令中設(shè)置如下字段和數(shù)據(jù)表別名: SELECT A1.store_name Store, SUM(Sales) "Total Sales" FROM Store_Information A1 GROUP BY A1.store_name 查詢結(jié)果顯示為: Store Total Sales Los Angeles $1800 San Diego $250 Boston $700 連接多個(gè)數(shù)據(jù)表 最后,我們來(lái)看一下如果使用SQL語(yǔ)言連接多個(gè)數(shù)據(jù)表,實(shí)現(xiàn)對(duì)多個(gè)數(shù)據(jù)表的查詢。為方便講解,我們?cè)跀?shù)據(jù)庫(kù)中分別創(chuàng)建了兩個(gè)名為Store_Information和Region的數(shù)據(jù)表
29、。 Store_Information Store_Name Sales Date Los Angeles $1500 Jan-10-2000 San Diego $250 Jan-11-2000 Los Angeles $300 Jan-12-2000 Boston $700 Jan-12-2000 Region Region_Name Store_Name East Boston East New York West Los Angeles West San Diego 下面,我們就來(lái)看一下通過(guò)數(shù)據(jù)表的連接實(shí)現(xiàn)按不同區(qū)域查詢銷售額。
30、 我們注意到在名為Region的數(shù)據(jù)表中包含區(qū)域和商店兩個(gè)字段信息,而在名為Store_Information的數(shù)據(jù)表中則包含每一家商店的銷售信息。因此,為了得到按區(qū)域劃分的銷售信息,我們需要將兩個(gè)不同數(shù)據(jù)表的信息結(jié)合在一起進(jìn)行查詢。通過(guò)對(duì)上述兩個(gè)數(shù)據(jù)表的分析,我們發(fā)現(xiàn)每個(gè)數(shù)據(jù)表中都包含一個(gè)名為Store_Name的字段,因此,我們可以使用如下命令實(shí)現(xiàn)查詢目的: SELECT A1.region_name REGION, SUM(A2.Sales) SALES FROM Geography A1, Store_Information A2 WHERE A1.store_name = A2
31、.store_name GROUP BY A1.region_name 查詢結(jié)果顯示為: REGION SALES East $700 West $2050 說(shuō)明: 上述查詢命令的前兩行用于指定所要查詢的目標(biāo)字段,分別為Region數(shù)據(jù)表中的Region_Name字段和Store_Information數(shù)據(jù)表中Sales字段的記錄值總數(shù)。這里,我們?cè)O(shè)定兩個(gè)字段的別名分別為REGION和SALES,兩個(gè)數(shù)據(jù)表的別名分別為A1和A2。如果我們只使用字段別名而不設(shè)定數(shù)據(jù)表別名的話,上述SQL命令的第一行就變成 如下形式: SELECT Region.Region_Name REGIO
32、N, SUM(Store_Information.Sales) SALES 由此我們可以看出有效的使用數(shù)據(jù)表別名,可以極大的簡(jiǎn)化對(duì)多個(gè)數(shù)據(jù)表進(jìn)行操作的SQL命令。 上述查詢命令的第3行為WHERE從句,正是該從句設(shè)定了兩個(gè)數(shù)據(jù)表的連接條件。因?yàn)槲覀兿M_保Region數(shù)據(jù)表中的Store_Name字段能夠與Store_Information數(shù)據(jù)表中的同名字段相對(duì)應(yīng),所以我們規(guī)定兩個(gè)字段的記錄值應(yīng)當(dāng)相等。在連接多個(gè)數(shù)據(jù)表時(shí),一定要準(zhǔn)確設(shè)定數(shù)據(jù)表的連接條件,如果WHERE從句設(shè)定不正確,則可能導(dǎo)致查詢結(jié)果中出現(xiàn)眾多不相關(guān)的數(shù)據(jù) 基礎(chǔ)教程 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))1 為了建立交互站點(diǎn),你
33、需要使用數(shù)據(jù)庫(kù)來(lái)存儲(chǔ)來(lái)自訪問(wèn)者的信息。例如,你要建立一個(gè)職業(yè)介紹服務(wù)的站點(diǎn),你就需要存儲(chǔ)諸如個(gè)人簡(jiǎn)歷,所感興趣的工作等等這樣的信息。創(chuàng)建動(dòng)態(tài)網(wǎng)葉也需要使用數(shù)據(jù)庫(kù),如果你想顯示符合來(lái)訪者要求的最好的工作,你就需要從數(shù)據(jù)庫(kù)中取出這份工作的信息。你將會(huì)發(fā)現(xiàn),在許多情況下需要使用數(shù)據(jù)庫(kù)。 在這一章里,你將學(xué)會(huì)怎樣使用“結(jié)構(gòu)化查詢語(yǔ)言”(SQL〕來(lái)操作數(shù)據(jù)庫(kù)。SQL語(yǔ)言是數(shù)據(jù)庫(kù)的標(biāo)準(zhǔn)語(yǔ)言。在Active SeverPages中,無(wú)論何時(shí)你要訪問(wèn)一個(gè)數(shù)據(jù)庫(kù),你就要使用SQL語(yǔ)言。因此,掌握好SQL對(duì)ASP編程是非常重要的。 注意: 你可以把“SQL”讀作“sequel”,也可以按單個(gè)字母的讀音讀作S
34、-Q-L。 兩種發(fā)音都是正確的,每種發(fā)音各有大量的支持者。在本書(shū)里,認(rèn)為“SQL”讀作“sequel”。 通過(guò)這一章的學(xué)習(xí),你將理解怎樣用SQL實(shí)現(xiàn)數(shù)據(jù)庫(kù)查詢,你將學(xué)會(huì)怎樣使用這種查詢從數(shù)據(jù)表中取出信息,最后,你將學(xué)會(huì)怎樣設(shè)計(jì)和建立自己的數(shù)據(jù)庫(kù)。 注意: 通過(guò)下面幾章對(duì)SQL的介紹,你將對(duì)SQL有足夠的了解,從而可以有效地使用Active Sever Pages。但是,SQL是一種復(fù)雜的語(yǔ)言,本書(shū)不可能包括它的全部細(xì)節(jié)。要全面掌握SQL語(yǔ)言,你需要學(xué)習(xí)在Microsoft SQL Sever中使用SQL。你可以到附近的書(shū)店去買一本Microsoft SQL Sever 6.5。 SQL
35、介紹: 本書(shū)假設(shè)你是在SQL操作Microsoft SQL Sever的數(shù)據(jù)庫(kù)。你也可以用SQL操作許多其它類型的數(shù)據(jù)庫(kù)。SQL是操作數(shù)據(jù)庫(kù)的標(biāo)準(zhǔn)語(yǔ)言。(事實(shí)上,關(guān)于SQL語(yǔ)言有一個(gè)專門的ANSI標(biāo)準(zhǔn)〕 注意: 不要在你的站點(diǎn)上試圖用Microsoft Access代替Microsoft SQL Sever。SQL Sever可以同時(shí)服務(wù)于許多用戶,如果你希望你的站點(diǎn)有較高的訪問(wèn)率,MS Access是不能勝任的。 在學(xué)習(xí)SQL的細(xì)節(jié)之前,你需要理解它的兩大特點(diǎn)。一個(gè)特點(diǎn)容易掌握,另一個(gè)掌握起來(lái)有點(diǎn)困難。 第一個(gè)特點(diǎn)是所有SQL數(shù)據(jù)庫(kù)中的數(shù)據(jù)都存儲(chǔ)在表中。一個(gè)表由行和列組成。例如,下
36、面這個(gè)簡(jiǎn)單的表包括name和e-mail address: Name Email Address ................................................................ Bill Gates billg@ president Clinton president@ Stephen Walther swalther@ 這個(gè)表有兩列(列也稱為字段,域〕:Name和Email Address。有三行,每一行包含一組數(shù)據(jù)。一行中的數(shù)據(jù)組合在一起稱為一條記錄。 無(wú)論何時(shí)你向表中添加新數(shù)據(jù),你就添加了一條新記錄。一個(gè)數(shù)據(jù)表可以有幾十
37、個(gè)記錄,也可以有幾千甚至幾十億個(gè)記錄。雖然你也許永遠(yuǎn)不需要存儲(chǔ)十億個(gè)Email地址,但知道你能這樣做總是好的,也許有一天你會(huì)有這樣的需要。 你的數(shù)據(jù)庫(kù)很有可能包含幾十個(gè)表,所有存儲(chǔ)在你數(shù)據(jù)庫(kù)中的信息都被存儲(chǔ)在這些表中。當(dāng)你考慮怎樣把信息存儲(chǔ)在數(shù)據(jù)庫(kù)中時(shí),你應(yīng)該考慮怎樣把它們存儲(chǔ)在表中。 SQL的第二個(gè)特點(diǎn)有些難于掌握。這種語(yǔ)言被設(shè)計(jì)為不允許你按照某種特定的順序來(lái)取出記錄,因?yàn)檫@樣做會(huì)降低SQL Sever取記錄的效率。使用SQL,你只能按查詢條件來(lái)讀取記錄。 當(dāng)考慮如何從表中取出記錄時(shí),自然會(huì)想到按記錄的位置讀取它們。例如,也許你會(huì)嘗試通過(guò)一個(gè)循環(huán),逐個(gè)記錄地掃描,來(lái)選出特定的記錄。在使
38、用SQL時(shí),你必須訓(xùn)練自己,不要有這種思路。 假如你想選出所有的名字是“Bill Gates”的記錄,如果使用傳統(tǒng)的編程語(yǔ)言,你也許會(huì)構(gòu)造一個(gè)循環(huán),逐個(gè)查看表中的記錄,看名字域是否是“Bill Gates”。 這種選擇記錄的方法是可行的,但是效率不高。使用SQL,你只要說(shuō),“選擇所有名字域等于Bill Gates的記錄”,SQL就會(huì)為你選出所有符合條件的記錄。SQL會(huì)確定實(shí)現(xiàn)查詢的最佳方法。 建設(shè)你想取出表中的前十個(gè)記錄。使用傳統(tǒng)的編程語(yǔ)言,你可以做一個(gè)循環(huán),取出前十個(gè)記錄后結(jié)束循環(huán)。但使用標(biāo)準(zhǔn)的SQL查詢,這是不可能實(shí)現(xiàn)的。從SQL的角度來(lái)說(shuō),在一個(gè)表中不存在前十個(gè)記錄這種概念。 開(kāi)
39、始時(shí),當(dāng)你知道你不能用SQL實(shí)現(xiàn)某些你感覺(jué)應(yīng)該能實(shí)現(xiàn)的功能,你會(huì)受到挫折。你也許會(huì)以頭撞墻甚至想寫惡毒的信件給SQL的設(shè)計(jì)者們。但后來(lái)你會(huì)認(rèn)識(shí)到,SQL的這個(gè)特點(diǎn)不僅不是個(gè)限制,反而是其長(zhǎng)處。因?yàn)镾QL不根據(jù)位置來(lái)讀取記錄,它讀取記錄可以很快。 綜上所述,SQL有兩個(gè)特點(diǎn):所有數(shù)據(jù)存儲(chǔ)在表中,從SQL的角度來(lái)說(shuō),表中的記錄沒(méi)有順序。在下一節(jié),你將學(xué)會(huì)怎樣用SQL從表中選擇特殊的記錄。 使用SQL從表中取記錄。 SQL的主要功能之一是實(shí)現(xiàn)數(shù)據(jù)庫(kù)查詢。如果你熟悉Internet引擎,那么你已經(jīng)熟悉查詢了。你使用查詢來(lái)取得滿足特定條件的信息。例如,如果你想找到有ASP信息的全部站點(diǎn),你可以連接
40、到 Yahoo!并執(zhí)行一個(gè)對(duì)Active Sever Pages的搜索。在你輸入這個(gè)查詢后,你會(huì)收到一個(gè)列表,表中包括所有其描述中包含搜索表達(dá)式的站點(diǎn)。 多數(shù)Internet引擎允許邏輯查詢。在邏輯查詢中,你可以包括特殊的運(yùn)算符如AND、OR和NOT,你使用這些運(yùn)算符來(lái)選擇特定的記錄。例如,你可以用AND來(lái)限制查詢結(jié)果。如果你執(zhí)行一個(gè)對(duì)Active Sever Pages AND SQL的搜索。你將得到其描述中同時(shí)包含Active Sever Pages和SQL的記錄。當(dāng)你需要限制查詢結(jié)果時(shí),你可以使用AND。 如果你需要擴(kuò)展查詢的結(jié)果,你可以使用邏輯操作符OR。例如,如果你執(zhí)行一個(gè)搜索,
41、搜索所有的其描述中包含Active Sever Pages OR SQL的站點(diǎn),你收到的列表中將包括所有其描述中同時(shí)包含兩個(gè)表達(dá)式或其中任何一個(gè)表達(dá)式的站點(diǎn)。 如果你想從搜索結(jié)果中排除特定的站點(diǎn),你可以使用NOT。例如,查詢“Active Sever Pages ”AND NOT “SQL”將返回一個(gè)列表,列表中的站點(diǎn)包含Active Sever Pages,但不包含SQL。當(dāng)必須排除特定的記錄時(shí),你可以使用NOT。 用SQL執(zhí)行的查詢與用Internet搜索引擎執(zhí)行的搜索非常相似。當(dāng)你執(zhí)行一個(gè)SQL查詢時(shí),通過(guò)使用包括邏輯運(yùn)算符的查詢條件,你可以得到一個(gè)記錄列表。此時(shí)查詢結(jié)果是來(lái)自一個(gè)或
42、多個(gè)表。 SQL查詢的句法非常簡(jiǎn)單。假設(shè)有一個(gè)名為email_table的表,包含名字和地址兩個(gè)字段,要得到Bill Gates的e_mail地址,你可以使用下面的查詢: SELECT email from email_table WHERE name="Bill Gates" 當(dāng)這個(gè)查詢執(zhí)行時(shí),就從名為email_table的表中讀取Bill Gates的e_mail地址。這個(gè)簡(jiǎn)單的語(yǔ)句包括三部分: ■ SELECT語(yǔ)句的第一部分指名要選取的列。在此例中,只有email列被選取。當(dāng)執(zhí)行 時(shí),只顯示email列的值 billg@。 ■ SELECTT語(yǔ)句的第二部份指明要從哪個(gè)(些)表
43、中查詢數(shù)據(jù)。在此例中,要查詢的表名為email_table。 ■最后,SELECT語(yǔ)句的WHERE子句指明要選擇滿足什么條件的記錄。在此例中,查詢條件為只有name列的值為Bill Gates的記錄才被選取。 Bill Gates很有可能擁有不止一個(gè)email地址。如果表中包含Bill Gates的多個(gè)email地址。用上述的SELECT語(yǔ)句可以讀取他所有的email地址。SELECT語(yǔ)句從表中取出所有name字段值為Bill Gates的記錄的email字段的值。 前面說(shuō)過(guò),查詢可以在查詢條件中包含邏輯運(yùn)算符。假如你想讀取Bill Gates或Clinton總統(tǒng)的所有email地址,你
44、可以使用下面的查詢語(yǔ)句: SELECT email FROM email_table WHERE name="Bill Gates" OR name="president Clinton" 此例中的查詢條件比前一個(gè)復(fù)雜了一點(diǎn)。這個(gè)語(yǔ)句從表email_table中選出所有name列為Bill Gates或president Clinton的記錄。如果表中含有Bill Gates或president Clinton的多個(gè)地址,所有的地址都被讀取。 SELECT語(yǔ)句的結(jié)構(gòu)看起來(lái)很直觀。如果你請(qǐng)一個(gè)朋友從一個(gè)表中為你選擇一組記錄,你也許以非常相似的方式提出你的要求。在SQL SELECT語(yǔ)句
45、中,你“SELECT特定的列FROM一個(gè)表WHERE某些列滿足一個(gè)特定的條件”。 下一節(jié)將介紹怎樣執(zhí)行SQL查詢來(lái)選取記錄。這將幫助你熟悉用SELECT語(yǔ)句從表中取數(shù)據(jù)的各種不同方法。 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))2 使用ISQL執(zhí)行SELECT查詢 當(dāng)你安裝SQL Sever時(shí),你同時(shí)安裝了一個(gè)叫作ISQL/w的應(yīng)用程序。ISQL/w允許你執(zhí)行交互的SQL查詢。在把查詢包括到你的ASP網(wǎng)頁(yè)中之前,用ISQL/w對(duì)其進(jìn)行測(cè)試是非常有用的。 注意: 在這本書(shū)的第一部份,你學(xué)習(xí)了怎樣安裝和配置Microsoft SQL Sever。如果沒(méi)有安裝SQL Sever或者SQL Sever
46、不能運(yùn)行,請(qǐng)參閱第三章“安裝和使用SQL Sever”。 選擇任務(wù)上SQL Sever程序組中的ISQL_w以啟動(dòng)該程序。程序啟動(dòng)時(shí),首先會(huì)出現(xiàn)一個(gè)對(duì)話框,要求輸入服務(wù)器信息和登錄信息。在Sever框中,輸入你的SQL服務(wù)器的名字。如果服務(wù)器正運(yùn)行在本地計(jì)算機(jī)上,服務(wù)器名字就是你計(jì)算機(jī)的名字。在登錄信息框中,輸入一個(gè)登錄帳號(hào)和密碼或選擇使用“可信連接”,然后單擊Connect按鈕。 注意: 如果你將SQL Sever配置為使用完整安全或混合安全,那么你可以使用可信連接。如果你使用標(biāo)準(zhǔn)安全,你則需要提供用戶帳號(hào)和密碼。要了解更多信息,參見(jiàn)第三章。 如果一切正常,在你單擊連接按鈕后會(huì)出現(xiàn)
47、一個(gè)查詢窗口。(如果有異常,請(qǐng)參考第三章) 在執(zhí)行查詢之前,你需要選擇數(shù)據(jù)庫(kù)。安裝 SQL Sever時(shí)你已為自己創(chuàng)建了一個(gè)數(shù)據(jù)庫(kù),SQL Sever還有許多系統(tǒng)數(shù)據(jù)庫(kù),如master,model,msdb,和tempdb。 方便的是,SQL Sever帶有一個(gè)特殊的名為pubs的例子數(shù)據(jù)庫(kù)。庫(kù) pubs中包含供一個(gè)虛擬的出版商使用的各個(gè)表。文檔中所有的例子程序都是針對(duì)這個(gè)庫(kù)來(lái)設(shè)計(jì)的。本書(shū)中的許多例子也使用這個(gè)數(shù)據(jù)庫(kù)。 在查詢窗口頂部的DB下拉框中選擇數(shù)據(jù)庫(kù)pubs,這樣你就選擇了數(shù)據(jù)庫(kù)。你所有的查詢都將針對(duì)這個(gè)庫(kù)中的各個(gè)表來(lái)執(zhí)行。現(xiàn)在你可以執(zhí)行你的第一個(gè)查詢了。這真讓人興奮! 你的
48、第一個(gè)查詢將針對(duì)一個(gè)名為autrors的表,表中包含所有為某個(gè)虛擬出版商工作的作者的相關(guān)數(shù)據(jù)。單擊查詢窗口并輸入以下的語(yǔ)句: SELECT phone FROM authors WHERE au_name="Ringer" 輸入完成后,單擊執(zhí)行查詢按鈕(一個(gè)綠色三角形,看起來(lái)像VCR播放鍵)。單擊此按鈕后,任何出現(xiàn)在查詢窗口中的語(yǔ)句均會(huì)被執(zhí)行。查詢窗口會(huì)自動(dòng)變成結(jié)果顯示窗口,你可以看到查詢的結(jié)果。 在SQL Sever的不同版本中,庫(kù)pubs中的數(shù)據(jù)會(huì)有所不同。對(duì)SQL Sever 6.5來(lái)說(shuō),將會(huì)找到兩條記錄。結(jié)果顯示窗口中應(yīng)顯示如下內(nèi)容: phone ………………. 801 8
49、26_0752 801 826_0752 (2 row(s) affected) 你所執(zhí)行的SELECT語(yǔ)句從表authors中取出所有名字為Ringer的作者的電話號(hào)碼。你通過(guò)在WHERE子句中使用特殊的選擇條件來(lái)限制查詢的結(jié)果。你也可以忽略選擇條件,從表中取出所有作者的電話號(hào)碼。要做到這一點(diǎn),單擊Query標(biāo)簽,返回到查詢窗口,輸入以下的SELECT語(yǔ)句: SELECT Phone FROM authors 這個(gè)查詢執(zhí)行后,會(huì)取出表authors中的所有電話號(hào)碼(沒(méi)有特定的順序)。如果表authors中包含一百個(gè)電話號(hào)碼,會(huì)有一百個(gè)記錄被取出,如果表中有十億個(gè)電話號(hào)碼,這十億條記
50、錄都會(huì)被取出(這也許需要一些時(shí)間)。 表authrs的字段包括姓,名字,電話號(hào)碼,地址,城市,州和郵政編碼。通過(guò)在SELECT語(yǔ)句的第一部份指定它們,你可以從表中取出任何一個(gè)字段。你可以在一個(gè)SELECT語(yǔ)句中一次取出多個(gè)字段,比如: SELECT au_fname ,au_lname, phone FROM authors 這個(gè)SELECT語(yǔ)句執(zhí)行后,將取出這三個(gè)列的所有值。下面是這個(gè)查詢的結(jié)果的一個(gè)示例(為了節(jié)省紙張,只顯示查詢結(jié)果的一部分,其余記錄用省略號(hào)代替): au_fname au_lname phone …………………………………………………………………………. J
51、ohnson White 408 496_7223 Marjorie Green 415 986_7020 Cheryl Carson 415 548_7723 Michael O’Leary 408 286_2428 … (23 row(s) affected) 在SELECT語(yǔ)句中,你需要列出多少個(gè)字段,你就可以列出多少。不要忘了把字段名用逗號(hào)隔開(kāi)。你也可以用星號(hào)(*)從一個(gè)表中取出所有的字段。這里有一個(gè)使用星號(hào)的例子: SELECT * FROM authors 這個(gè)SELECT語(yǔ)句執(zhí)行后,表中的所有字段的值都被取出。你會(huì)發(fā)現(xiàn)你將在SQL查詢中頻繁使用星號(hào)。 技巧:
52、 你可以使用星號(hào)來(lái)查看一個(gè)表的所有列的名字。要做到這一點(diǎn),只需要在執(zhí)行完SELECT語(yǔ)句后看一下查詢結(jié)果的列標(biāo)題。 操作多個(gè)表 到現(xiàn)在為止,你只嘗試了用一句SQL查詢從一個(gè)表中取出數(shù)據(jù)。你也可以用一個(gè)SELECT語(yǔ)句同時(shí)從多個(gè)表中取出數(shù)據(jù),只需在SELECT語(yǔ)句的FROM從句中列出要從中取出數(shù)據(jù)的表名稱即可: SELECT au_lname ,title FROM authors, titles 這個(gè)SELECT語(yǔ)句執(zhí)行時(shí),同時(shí)從表authors和表titles中取出數(shù)據(jù)。從表authors中取出所有的作者名字,從表titles中取出所有的書(shū)名。在ISQL/w程序中執(zhí)行這個(gè)查詢,看一
53、下查詢結(jié)果。你會(huì)發(fā)現(xiàn)一些奇怪的出乎意料的情況:作者的名字并沒(méi)有和它們所著的書(shū)相匹配,而是出現(xiàn)了作者名字和書(shū)名的所有可能的組合,這也許不是你所希望見(jiàn)到的。 出了什么差錯(cuò)?問(wèn)題在于你沒(méi)有指明這兩個(gè)表之間的關(guān)系。你沒(méi)有通過(guò)任何方式告訴SQL如何把表和表關(guān)聯(lián)在一起。由于不知道如何關(guān)聯(lián)兩個(gè)表,服務(wù)器只能簡(jiǎn)單地返回取自兩個(gè)表中的記錄的所有可能組合。 要從兩個(gè)表中選出有意義的記錄組合,你需要通過(guò)建立兩表中字段的關(guān)系來(lái)關(guān)聯(lián)兩個(gè)表。要做到這一點(diǎn)的途徑之一是創(chuàng)建第三個(gè)表,專門用來(lái)描述另外兩個(gè)表的字段之間的關(guān)系。 表authors有一個(gè)名為au_id的字段,包含有每個(gè)作者的唯一標(biāo)識(shí)。表titles有一個(gè)名為t
54、itle_id的字段,包含每個(gè)書(shū)名的唯一標(biāo)識(shí)。如果你能在字段au_id和字段title_id之間建立一個(gè)關(guān)系,你就可以關(guān)聯(lián)這兩個(gè)表。數(shù)據(jù)庫(kù)pubs中有一個(gè)名為titleauthor的表,正是用來(lái)完成這個(gè)工作。表中的每個(gè)記錄包括兩個(gè)字段,用來(lái)把表titles和表authors關(guān)聯(lián)在一起。下面的SELECT語(yǔ)句使用了這三個(gè)表以得到正確的結(jié)果: SELECT au_name,title FROM authors,titles,titleauthor WHERE authors.au_id=titleauthor.au_id AND titles.title_id=titleauthor.ti
55、tle_id 當(dāng)這個(gè)SELECT語(yǔ)句執(zhí)行時(shí),每個(gè)作者都將與正確的書(shū)名相匹配。表titleauthor指明了表authors和表titles的關(guān)系,它通過(guò)包含分別來(lái)自兩個(gè)表的各一個(gè)字段實(shí)現(xiàn)這一點(diǎn)。第三個(gè)表的唯一目的是在另外兩個(gè)表的字段之間建立關(guān)系。它本身不包含任何附加數(shù)據(jù)。 注意在這個(gè)例子中字段名是如何書(shū)寫的。為了區(qū)別表authors和表titles中相同的字段名au_id,每個(gè)字段名前面都加上了表名前綴和一個(gè)句號(hào)。名為author.au_id的字段屬于表authors,名為titleauthor.au_id的字段屬于表titleauthor,兩者不會(huì)混淆。 通過(guò)使用第三個(gè)表,你可以在兩
56、個(gè)表的字段之間建立各種類型的關(guān)系。例如,一個(gè)作者也許寫了許多不同的書(shū),或者一本書(shū)也許由許多不同的作者共同完成。當(dāng)兩個(gè)表的字段之間有這種“多對(duì)多”的關(guān)系時(shí),你需要使用第三個(gè)表來(lái)指明這種關(guān)系。 但是,在許多情況下,兩個(gè)表之間的關(guān)系并不復(fù)雜。比如你需要指明表titles和表publishers之間的關(guān)系。因?yàn)橐粋€(gè)書(shū)名不可能與多個(gè)出版商相匹配,你不需要通過(guò)第三個(gè)表來(lái)指明這兩個(gè)表之間的關(guān)系。要指明表titles和表publishers之間的關(guān)系,你只要讓這兩個(gè)表有一個(gè)公共的字段就可以了。在數(shù)據(jù)庫(kù)pubs中,表titles和表publishers都有一個(gè)名為pub_id的字段。如果你想得到書(shū)名及其出版商
57、的一個(gè)列表,你可以使用如下的語(yǔ)句: SELECT title,pub_name FROM titles,publishers WHERE titles.pub_id=publishers.pub_id 當(dāng)然,如果一本書(shū)是由兩個(gè)出版商聯(lián)合出版的,那么你需要第三個(gè)表來(lái)代表這種關(guān)系。 通常,當(dāng)你予先知道兩個(gè)表的字段間存在“多對(duì)多”關(guān)系時(shí),就使用第三個(gè)表來(lái)關(guān)聯(lián)這兩個(gè)表。反之,如果兩個(gè)表的字段間只有“一對(duì)一”或“一對(duì)多”關(guān)系,你可以使用公共字段來(lái)關(guān)聯(lián)它門。 SQL數(shù)據(jù)操作基礎(chǔ)(初級(jí))3 操作字段 通常,當(dāng)你從一個(gè)表中取出字段值時(shí),該值與創(chuàng)建該表時(shí)所定義的字段名聯(lián)系在一起。如果你從表auth
58、ors中選擇所有的作者名字,所有的值將會(huì)與字段名au_lname相聯(lián)系。但是在某些情況下,你需要對(duì)字段名進(jìn)行操作。在SELECT語(yǔ)句中,你可以在缺省字段名后面僅跟一個(gè)新名字來(lái)取代它。例如,可以用一個(gè)更直觀易讀的名字Author Last Name來(lái)代替字段名au_lname: SELECT au_lname "Author Last Name" FROM authors 當(dāng)這個(gè)SELECT語(yǔ)句執(zhí)行時(shí),來(lái)自字段au_lname的值會(huì)與“Author Last Name”相聯(lián)系。查詢結(jié)果可能是這樣: Author Last Name …………………………………………………………………….
59、. White Green Carson O’Leary Straight … (23 row(s) affected) 注意字段標(biāo)題不再是au_lname,而是被Author Last Name所取代。 你也可以通過(guò)執(zhí)行運(yùn)算,來(lái)操作從一個(gè)表返回的字段值。例如,如果你想把表titles中的所有書(shū)的價(jià)格加倍,你可以使用下面的SELECT語(yǔ)句: SELECT price*2 FROM titles 當(dāng)這個(gè)查詢執(zhí)行時(shí),每本書(shū)的價(jià)格從表中取出時(shí)都會(huì)加倍。但是,通過(guò)這種途徑操作字段不會(huì)改變存儲(chǔ)在表中的書(shū)價(jià)。對(duì)字段的運(yùn)算只會(huì)影響SELECT語(yǔ)句的輸出,而不會(huì)影響表中的數(shù)據(jù)。為了
60、同時(shí)顯示書(shū)的原始價(jià)格和漲價(jià)后的新價(jià)格,你可以使用下面的查詢: SELECT price "Original price", price*2 "New price" FROM titles 當(dāng)數(shù)據(jù)從表titles中取出時(shí),原始價(jià)格顯示在標(biāo)題Original price下面,加倍后的價(jià)格顯示在標(biāo)題New price下面。結(jié)果可能是這樣: original price new price ………………………………………………………………. 39.98 11.95 23.90 5.98 39.98 … (18 row(s) affected) 你可以使用大多數(shù)標(biāo)準(zhǔn)的數(shù)學(xué)運(yùn)
61、算符來(lái)操作字段值,如加(+),減(-),乘(*)和除(/)。你也可以一次對(duì)多個(gè)字段進(jìn)行運(yùn)算,例如: SELECT price*ytd_sales "total revenue" FROM titles 在這個(gè)例子中,通過(guò)把價(jià)格與銷售量相乘,計(jì)算出了每種書(shū)的總銷售額。這個(gè)SELECT語(yǔ)句的結(jié)果將是這樣的: total revenue …………………………………………….. 81,859,05 46,318,20 55,978,78 81,859,05 40,619,68 … (18 row(s) affected) 最后,你還可以使用連接運(yùn)算符(它看起來(lái)像個(gè)加號(hào))來(lái)連接兩
62、個(gè)字符型字段: SELECT au_fname+" "+au_lname "author name" FROM authors 在這個(gè)例子中,你把字段au_fname和字段au_lname粘貼在一起,中間用一個(gè)逗號(hào)隔開(kāi),并把查詢結(jié)果的標(biāo)題指定為author name。這個(gè)語(yǔ)句的執(zhí)行結(jié)果將是這樣的: author names ………………………………………………………… Johnson White Marjorie Green Cheryl Carson Michael O’Leary Dean Straight … (23 row(s) affected) 可以看到,S
63、QL為你提供了對(duì)查詢結(jié)果的許多控制。你應(yīng)該在ASP編程過(guò)程中充分利用這些優(yōu)點(diǎn)。使用SQL來(lái)操作查詢結(jié)果幾乎總是比使用有同樣作用的腳本效率更高。 排序查詢結(jié)果 本章的介紹中曾強(qiáng)調(diào)過(guò),SQL表沒(méi)有內(nèi)在的順序。例如,從一個(gè)表中取第二個(gè)記錄是沒(méi)有意義的。從SQL的角度看來(lái),沒(méi)有一個(gè)記錄在任何其他記錄之前。 然而,你可以操縱一個(gè)SQL查詢結(jié)果的順序。在缺省情況下,當(dāng)記錄從表中取出時(shí),記錄不以特定的順序出現(xiàn)。例如,當(dāng)從表authors中取出字段au_lname時(shí),查詢結(jié)果顯示成這樣: au_lname ……………………………………. White Green Carson O’Leary
64、 Straight … (23 row(s) affected) 看一列沒(méi)有特定順序的名字是很不方便的。如果把這些名字按字母順序排列,讀起來(lái)就會(huì)容易得多。通過(guò)使用ORDER BY子句,你可以強(qiáng)制一個(gè)查詢結(jié)果按升序排列,就像這樣: SELECT au_lname FROM authors ORDER BY au_lname 當(dāng)這個(gè)SELECT語(yǔ)句執(zhí)行時(shí),作者名字的顯示將按字母順序排列。ORDER BY子句將作者名字按升序排列。 你也可以同時(shí)對(duì)多個(gè)列使用ORDER BY子句。例如,如果你想同時(shí)按升序顯示字段au_lname和字段au_fname,你需要對(duì)兩個(gè)字段都進(jìn)行排序: SELE
65、CT au_lname,au_fname FROM authors ORDER BY au_lname ,au_fname 這個(gè)查詢首先把結(jié)果按au_lname字段進(jìn)行排序,然后按字段au_fname排序。記錄將按如下的順序取出: au_lname au_fname ……………………………………………………………………. Bennet Abraham Ringer Albert Ringer Anne Smith Meander … (23 row(s) affected) 注意有兩個(gè)作者有相同的名字Ringer。名為Albert Ringer的作者出現(xiàn)名為Anne Rin
66、ger的作者之前,這是因?yàn)樾誂lbert按字母順序應(yīng)排在姓Anne之前。 如果你想把查詢結(jié)果按相反的順序排列,你可以使用關(guān)鍵字DESC。關(guān)鍵字DESC把查詢結(jié)果按降序排列,如下例所示: SELECT au_lname,au_fname FROM authors WHERE au_lname=”Ringer” ORDER BY au_lname ,au_fname DESC 這個(gè)查詢從表authors中取出所有名字為Ringer的作者記錄。ORDER BY子句根據(jù)作者的名字和姓,將查詢結(jié)果按降序排列。結(jié)果是這樣的: au_lname au_fname ………………………………………………………………………………………. Ringer Anne Ringer Albert (2 row(s) affectec) 注意在這個(gè)表中,姓Anne出現(xiàn)在姓Albert之前。作者名字按降序顯示。 你也可以按數(shù)值型字段對(duì)一個(gè)查詢結(jié)果進(jìn)行排序。例如,如果你想按降序取出所有書(shū)的價(jià)
- 溫馨提示:
1: 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)6整理和復(fù)習(xí)2圖形與幾何第7課時(shí)圖形的位置練習(xí)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)6整理和復(fù)習(xí)2圖形與幾何第1課時(shí)圖形的認(rèn)識(shí)與測(cè)量1平面圖形的認(rèn)識(shí)練習(xí)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)6整理和復(fù)習(xí)1數(shù)與代數(shù)第10課時(shí)比和比例2作業(yè)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)4比例1比例的意義和基本性質(zhì)第3課時(shí)解比例練習(xí)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)3圓柱與圓錐1圓柱第7課時(shí)圓柱的體積3作業(yè)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)3圓柱與圓錐1圓柱第1節(jié)圓柱的認(rèn)識(shí)作業(yè)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)2百分?jǐn)?shù)(二)第1節(jié)折扣和成數(shù)作業(yè)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)1負(fù)數(shù)第1課時(shí)負(fù)數(shù)的初步認(rèn)識(shí)作業(yè)課件新人教版
- 2023年六年級(jí)數(shù)學(xué)上冊(cè)期末復(fù)習(xí)考前模擬期末模擬訓(xùn)練二作業(yè)課件蘇教版
- 2023年六年級(jí)數(shù)學(xué)上冊(cè)期末豐收?qǐng)@作業(yè)課件蘇教版
- 2023年六年級(jí)數(shù)學(xué)上冊(cè)易錯(cuò)清單十二課件新人教版
- 標(biāo)準(zhǔn)工時(shí)講義
- 2021年一年級(jí)語(yǔ)文上冊(cè)第六單元知識(shí)要點(diǎn)習(xí)題課件新人教版
- 2022春一年級(jí)語(yǔ)文下冊(cè)課文5識(shí)字測(cè)評(píng)習(xí)題課件新人教版
- 2023年六年級(jí)數(shù)學(xué)下冊(cè)6整理和復(fù)習(xí)4數(shù)學(xué)思考第1課時(shí)數(shù)學(xué)思考1練習(xí)課件新人教版