SQL非常全面的入門教程
《SQL非常全面的入門教程》由會員分享,可在線閱讀,更多相關(guān)《SQL非常全面的入門教程(83頁珍藏版)》請在裝配圖網(wǎng)上搜索。
SQL語言快速入門入門教程 ......................................................................................................................2SQL 語言快速入門之一 .........................................................................................2SQL 語言快速入門之二 .........................................................................................3SQL 語言快速入門之三 .........................................................................................5基礎(chǔ)教程 ....................................................................................................................10SQL 數(shù)據(jù)操作基礎(chǔ)(初級)1 ..................................................................................10SQL 數(shù)據(jù)操作基礎(chǔ)(初級)2 ..................................................................................13SQL 數(shù)據(jù)操作基礎(chǔ)(初級)3 ..................................................................................16SQL 數(shù)據(jù)操作基礎(chǔ)(初級)4 ..................................................................................20SQL 數(shù)據(jù)操作基礎(chǔ)(初級)5 ..................................................................................25SQL 數(shù)據(jù)操作基礎(chǔ)(中級) ...........................................................................................27SQL 數(shù)據(jù)操作基礎(chǔ)(中級)1 ..................................................................................27SQL 數(shù)據(jù)操作基礎(chǔ)(中級)2 ..................................................................................28SQL 數(shù)據(jù)操作基礎(chǔ)(中級)3 ..................................................................................31SQL 數(shù)據(jù)操作基礎(chǔ)(中級)4 ..................................................................................35SQL 數(shù)據(jù)操作基礎(chǔ)(中級)5 ..................................................................................39全面接觸 SQL............................................................................................................44全面接觸 SQL 語法(1) ........................................................................................44全面接觸 SQL 語法(2) ........................................................................................46全面接觸 SQL 語法(3) ........................................................................................47全面接觸 SQL 語法(4) ........................................................................................49全面接觸 SQL 語法(5) ........................................................................................51全面接觸 SQL 語法(6) ........................................................................................53全面接觸 SQL 語法(7) ........................................................................................55SQL 語法詳解 ............................................................................................................59主要 SQL 語句詳解 (1) ........................................................................................59主要 SQL 語句詳解 (2) ........................................................................................63SQL 語法參考手冊 ..............................................................................................67SQL 實踐 ...................................................................................................................71SQL 實踐 (1)........................................................................................................71SQL 實踐 (2)........................................................................................................75Sql 連接查詢 .......................................................................................................80入門教程SQL 語言快速入門之一SQL 是英文 Structured Query Language 的縮寫,意思為結(jié)構(gòu)化查詢語言。SQL 語言的主要功能就是同各種數(shù)據(jù)庫建立聯(lián)系,進行溝通。按照 ANSI(美國國家標(biāo)準(zhǔn)協(xié)會)的規(guī)定,SQL 被作為關(guān)系型數(shù)據(jù)庫管理系統(tǒng)的標(biāo)準(zhǔn)語言。SQL 語句可以用來執(zhí)行各種各樣的操作,例如更新數(shù)據(jù)庫中的數(shù)據(jù),從數(shù)據(jù)庫中提取數(shù)據(jù)等。目前,絕大多數(shù)流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),如 Oracle, Sybase, Microsoft SQL Server, Access 等都采用了 SQL 語言標(biāo)準(zhǔn)。雖然很多數(shù)據(jù)庫都對 SQL 語句進行了再開發(fā)和擴展,但是包括 Select, Insert, Update, Delete, Create,以及 Drop 在內(nèi)的標(biāo)準(zhǔn)的 SQL 命令仍然可以被用來完成幾乎所有的數(shù)據(jù)庫操作。下面,我們就來詳細(xì)介紹一下 SQL 語言的基本知識。數(shù)據(jù)庫表格一個典型的關(guān)系型數(shù)據(jù)庫通常由一個或多個被稱作表格的對象組成。數(shù)據(jù)庫中的所有數(shù)據(jù)或信息都被保存在這些數(shù)據(jù)庫表格中。數(shù)據(jù)庫中的每一個表格都具有自己唯一的表格名稱,都是由行和列組成,其中每一列包括了該列名稱,數(shù)據(jù)類型,以及列的其它屬性等信息,而行則具體包含某一列的記錄或數(shù)據(jù)。以下,是一個名為天氣的數(shù)據(jù)庫表格的實例。城市 最高氣溫 最低氣溫 北京 10 5 上海 15 8 天津 8 2 重慶 20 13 該表格中“城市” , “最高氣溫”和“最低氣溫”就是三個不同的列,而表格中的每一行則包含了具體的表格數(shù)據(jù)。數(shù)據(jù)查詢在眾多的 SQL 命令中,select 語句應(yīng)該算是使用最頻繁的。Select 語句主要被用來對數(shù)據(jù)庫進行查詢并返回符合用戶查詢標(biāo)準(zhǔn)的結(jié)果數(shù)據(jù)。Select 語句的語法格式如下:select column1 [, column2,etc] from tablename[where condition];([]表示可選項)select 語句中位于 select 關(guān)鍵詞之后的列名用來決定那些列將作為查詢結(jié)果返回。用戶可以按照自己的需要選擇任意列,還可以使用通配符“*”來設(shè)定返回表格中的所有列。select 語句中位于 from 關(guān)鍵詞之后的表格名稱用來決定將要進行查詢操作的目標(biāo)表格。Select 語句中的 where 可選從句用來規(guī)定哪些數(shù)據(jù)值或哪些行將被作為查詢結(jié)果返回或顯示。在 where 條件從句中可以使用以下一些運算符來設(shè)定查詢標(biāo)準(zhǔn):=等于>大于=大于等于不等于除了上面所提到的運算符外,LIKE 運算符在 where 條件從句中也非常重要。LIKE 運算符的功能非常強大,通過使用 LIKE 運算符可以設(shè)定只選擇與用戶規(guī)定格式相同的記錄。此外,我們還可以使用通配符“%”用來代替任何字符串。舉例如下:select firstname, lastname, cityfrom employeewhere firstname LIKE ‘E%’;(注意,字符串必須被包含在單括號內(nèi))上述 SQL 語句將會查詢所有名稱以 E 開頭的姓名?;蛘?,通過如下語句:select * from employeewhere firstname = ‘May’;查詢所有名稱為 May 的行。SQL 語言快速入門之二創(chuàng)建表格SQL 語言中的 create table 語句被用來建立新的數(shù)據(jù)庫表格。Create table 語句的使用格式如下:create table tablename(column1 data type,column2 data type,column3 data type);如果用戶希望在建立新表格時規(guī)定列的限制條件,可以使用可選的條件選項: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));簡單來說,創(chuàng)建新表格時,在關(guān)鍵詞 create table 后面加入所要建立的表格的名稱,然后在括號內(nèi)順次設(shè)定各列的名稱,數(shù)據(jù)類型,以及可選的限制條件等。注意,所有的 SQL 語句在結(jié)尾處都要使用“;”符號。使用 SQL 語句創(chuàng)建的數(shù)據(jù)庫表格和表格中列的名稱必須以字母開頭,后面可以使用字母,數(shù)字或下劃線,名稱的長度不能超過30個字符。注意,用戶在選擇表格名稱時不要使用 SQL 語言中的保留關(guān)鍵詞,如 select, create, insert 等,作為表格或列的名稱。數(shù)據(jù)類型用來設(shè)定某一個具體列中數(shù)據(jù)的類型。例如,在姓名列中只能采用 varchar 或 char 的數(shù)據(jù)類型,而不能使用 number 的數(shù)據(jù)類型。SQL 語言中較為常用的數(shù)據(jù)類型為:char(size):固定長度字符串,其中括號中的 size 用來設(shè)定字符串的最大長度。Char 類型的最大長度為255字節(jié)。varchar(size):可變長度字符串,最大長度由 size 設(shè)定。number(size):數(shù)字類型,其中數(shù)字的最大位數(shù)由 size 設(shè)定。Date:日期類型。number(size,d):數(shù)字類型,size 決定該數(shù)字總的最大位數(shù),而 d 則用于設(shè)定該數(shù)字在小數(shù)點后的位數(shù)。最后,在創(chuàng)建新表格時需要注意的一點就是表格中列的限制條件。所謂限制條件就是當(dāng)向特定列輸入數(shù)據(jù)時所必須遵守的規(guī)則。例如,unique 這一限制條件要求某一列中不能存在兩個值相同的記錄,所有記錄的值都必須是唯一的。除 unique 之外,較為常用的列的限制條件還包括 not null 和 primary key 等。Not null 用來規(guī)定表格中某一列的值不能為空。Primary key 則為表格中的所有記錄規(guī)定了唯一的標(biāo)識符。向表格中插入數(shù)據(jù)SQL 語言使用 insert 語句向數(shù)據(jù)庫表格中插入或添加新的數(shù)據(jù)行。Insert語句的使用格式如下:insert into tablename(first_column,...last_column)values (first_value,...last_value);例如:insert into employee(firstname, lastname, age, address, city)values (‘Li’, ‘Ming’, 45, ‘No.77 Changan Road’, ‘Beijing”);簡單來說,當(dāng)向數(shù)據(jù)庫表格中添加新記錄時,在關(guān)鍵詞 insert into 后面輸入所要添加的表格名稱,然后在括號中列出將要添加新值的列的名稱。最后,在關(guān)鍵詞 values 的后面按照前面輸入的列的順序?qū)?yīng)的輸入所有要添加的記錄值。更新記錄SQL 語言使用 update 語句更新或修改滿足規(guī)定條件的現(xiàn)有記錄。Update 語句的格式為:update tablenameset columnname = newvalue [, nextcolumn = newvalue2...]where columnname OPERATOR value [and|or column OPERATOR value];例如:update employeeset age = age+1where first_name= ‘Mary’and last_name= ‘Williams’;使用 update 語句時,關(guān)鍵一點就是要設(shè)定好用于進行判斷的 where 條件從句。刪除記錄SQL 語言使用 delete 語句刪除數(shù)據(jù)庫表格中的行或記錄。Delete 語句的格式為:delete from tablenamewhere columnname OPERATOR value [and|or column OPERATOR value];例如:delete from employeewhere lastname = May;簡單來說,當(dāng)需要刪除某一行或某個記錄時,在 delete from 關(guān)鍵詞之后輸入表格名稱,然后在 where 從句中設(shè)定刪除記錄的判斷條件。注意,如果用戶在使用 delete 語句時不設(shè)定 where 從句,則表格中的所有記錄將全部被刪除。刪除數(shù)據(jù)庫表格在 SQL 語言中使用 drop table 命令刪除某個表格以及該表格中的所有記錄。Drop table 命令的使用格式為:drop table tablename;例如:drop table employee;如果用戶希望將某個數(shù)據(jù)庫表格完全刪除,只需要在 drop table 命令后輸入希望刪除的表格名稱即可。Drop table 命令的作用與刪除表格中的所有記錄不同。刪除表格中的全部記錄之后,該表格仍然存在,而且表格中列的信息不會改變。而使用 drop table 命令則會將整個數(shù)據(jù)庫表格的所有信息全部刪除。以上,我們對 SQL 語言主要的命令和語句進行了較為詳細(xì)的介紹。應(yīng)該說SQL 語句的語法結(jié)構(gòu)和風(fēng)格還是相當(dāng)簡單和直觀的,只要用戶結(jié)合實踐多加練習(xí),一定會在短期內(nèi)迅速掌握。SQL 語言快速入門之三我們?nèi)粘J褂?SQL 語言的工作過程中,使用最多的還是從已經(jīng)建立好的數(shù)據(jù)庫中查詢信息。下面,我們就來詳細(xì)介紹一下如何使用 SQL 語言實現(xiàn)各種數(shù)據(jù)庫查詢操作。SELECT…FROM為方便講解,我們在數(shù)據(jù)庫中創(chuàng)建名為 Store_Information 的如下數(shù)據(jù)表。Store_InformationStore_NameSalesDateLos Angeles$1500Jan-10-2000San Diego$250Jan-11-2000Los Angeles$300Jan-12-2000Boston$700Jan-12-2000SQL 語言中用于數(shù)據(jù)庫查詢的最簡單的命令就是 SELECT…FROM,語法格式為:SELECT "column_name" FROM "table_name"例如,如果我們希望查詢 Store_Information 數(shù)據(jù)表中所有的商店名稱時,可以使用如下命令:SELECT store_name FROM Store_Information查詢結(jié)果顯示為:Store_NameLos AngelesSan DiegoLos AngelesBoston如果用戶希望一次查詢多個字段,可以將所要查詢的字段名稱依次加入SELECT 關(guān)鍵字之后,中間用“, ”隔開即可。DISTINCTSELECT 關(guān)鍵字支持用戶查詢數(shù)據(jù)表中指定字段的所有數(shù)據(jù),但是這樣有時就會不可避免的出現(xiàn)重復(fù)信息。如果用戶希望只查詢那些具有不同記錄值的信息的話,可以使用 SQL 語言的 DISTINCT 關(guān)鍵字。語法格式如下:SELECT DISTINCT "column_name"FROM "table_name"例如,我們可以使用以下命令查詢 Store_Information 數(shù)據(jù)表具有不同記錄值的所有記錄。SELECT DISTINCT Store_Name FROM Store_Information查詢結(jié)果如下:Store_NameLos AngelesSan DiegoBostonWHERE除了選擇具有不同記錄值的記錄之外,有時我們可能還會需要根據(jù)某些條件對數(shù)據(jù)庫中的數(shù)據(jù)進行查詢。例如,我們可能需要查詢 Store_Information數(shù)據(jù)表中銷售額超過1000美圓的商店。為此,我們可以使用 SQL 語言的 WHERE關(guān)鍵字設(shè)定查詢條件。語法格式如下:SELECT "column_name"FROM "table_name"WHERE "condition"由此,我們可以使用如下命令查詢銷售額超過1000美圓的商店信息:SELECT store_name FROM Store_Information WHERE Sales > 1000查詢結(jié)果顯示為:store_nameLos Angeles運算函數(shù)現(xiàn)在,我們已經(jīng)了解到在使用 SQL 語言進行數(shù)據(jù)庫查詢操作時可以通過對數(shù)值的判斷設(shè)定靈活的查詢條件。為了增強對運算的支持能力,SQL 提供了眾多實用的運算函數(shù)供廣大用戶使用。例如,我們可以直接在 SQL 命令中調(diào)用SUM 或 AVG 這兩個分別用于計算總數(shù)和平均數(shù)的函數(shù)。語法格式如下:SELECT "function type"("column_name")FROM "table_name"如果我們希望查詢 Store_Information 數(shù)據(jù)表中所有商店的總銷售額的話,可以使用如下命令:SELECT SUM(Sales) FROM Store_Information查詢結(jié)果顯示為:SUM(Sales)$2750COUNT除了 SUM 和 AVG 函數(shù)之外,COUNT 函數(shù)是 SQL 語言中另一個較為常用的運算函數(shù)。COUNT 函數(shù)可以用來計算數(shù)據(jù)表中指定字段所包含的記錄數(shù)目。語法格式為:SELECT COUNT("column_name")FROM "table_name"例如,如果我們希望查詢 Store_Information 數(shù)據(jù)表中的有關(guān)商店的記錄條數(shù)時,可以使用如下命令:SELECT COUNT(store_name)FROM Store_Information查詢結(jié)果顯示為:Count(store_name)4COUNT 函數(shù)可以和 DISTINCT 關(guān)鍵字一起使用從而可以查詢數(shù)據(jù)表中指定字段中所有具有不同記錄值的記錄數(shù)目。例如,如果我們希望查詢Store_Information 數(shù)據(jù)表中不同商店的數(shù)目時,可以使用如下命令:SELECT COUNT(DISTINCT store_name)FROM Store_Information查詢結(jié)果顯示為:Count(DISTINCT store_name)3GROUP BY下面我們來進一步看一下 SQL 語言中的集合函數(shù)。上文中,我們曾使用SUM 函數(shù)計算所有商店的銷售總額,如果我們希望計算每一家商店各自的總銷售額時該怎么辦呢?要實現(xiàn)這一目的我們需要做兩件事:首先,我們需要查詢商店名稱和銷售額兩個字段;然后,我們使用 SQL 語言的 GROUP BY 命令將銷售額按照不同的商店進行分組,從而計算出不同商店的銷售總額。GROUP BY 命令的語法格式為:SELECT "column_name1", SUM("column_name2")FROM "table_name"GROUP BY "column_name1"我們可以使用如下命令實現(xiàn)上述查詢目的:SELECT store_name, SUM(Sales)FROM Store_InformationGROUP BY store_name查詢結(jié)果顯示為:store_name SUM(Sales)Los Angeles $1800San Diego $250Boston $700小注:GROUP BY 關(guān)鍵字一般應(yīng)用于同時查詢多個字段并對字段進行算術(shù)運算的SQL 命令中。HAVING用戶在使用 SQL 語言的過程中可能希望解決的另一個問題就是對由 sum 或其它集合函數(shù)運算結(jié)果的輸出進行限制。例如,我們可能只希望看到Store_Information 數(shù)據(jù)表中銷售總額超過1500美圓的商店的信息,這時我們就需要使用 HAVING 從句。語法格式為:SELECT "column_name1", SUM("column_name2")FROM "table_name"GROUP BY "column_name1"HAVING (arithematic function condition)(GROUP BY 從句可選)由此,我們可以使用如下命令實現(xiàn)上述查詢目的:SELECT store_name, SUM(sales)FROM Store_InformationGROUP BY store_nameHAVING SUM(sales) > 1500查詢結(jié)果顯示為:store_name SUM(Sales)Los Angeles $1800小注:SQL 語言中設(shè)定集合函數(shù)的查詢條件時使用 HAVING 從句而不是 WHERE 從句。通常情況下,HAVING 從句被放置在 SQL 命令的結(jié)尾處。ALIAS下面,我們重點介紹一下如何在 SQL 命令中設(shè)定別名。SQL 語言中一般使用兩種類型的別名,分別為字段別名和數(shù)據(jù)表別名。簡單的說,使用字段別名可以幫助我們有效的組織查詢的輸出結(jié)果。例如,上文所列舉的多個實例中,當(dāng)我們計算商店銷售總額時,顯示結(jié)果中就會出現(xiàn)SUM(sales)。雖然 SUM(sales)并不會對我們理解查詢結(jié)果帶來不便,但是如果我們需要在查詢中使用多項復(fù)雜運算時,顯示結(jié)果就不會這么直觀了。如果這時我們使用字段別名就會極大的提高查詢結(jié)果的可讀性。對于數(shù)據(jù)表別名,我們可以通過將別名直接放置在 FROM 從句中數(shù)據(jù)表名稱的后面設(shè)定。數(shù)據(jù)表別名在我們下面將要講述的連接多個數(shù)據(jù)表進行查詢的操作中極為有用。字段和數(shù)據(jù)表別名的語法格式如下:SELECT "table_alias"."column_name1" "column_alias"FROM "table_name" "table_alias"即別名都直接放置在各自對應(yīng)名稱的后面,中間用空格分開。以 Store_Information 數(shù)據(jù)表為例,我們可以在 GROUP BY 一節(jié)中所使用的SQL 命令中設(shè)置如下字段和數(shù)據(jù)表別名:SELECT A1.store_name Store, SUM(Sales) "Total Sales"FROM Store_Information A1GROUP BY A1.store_name查詢結(jié)果顯示為:Store Total SalesLos Angeles $1800San Diego $250Boston $700連接多個數(shù)據(jù)表最后,我們來看一下如果使用 SQL 語言連接多個數(shù)據(jù)表,實現(xiàn)對多個數(shù)據(jù)表的查詢。為方便講解,我們在數(shù)據(jù)庫中分別創(chuàng)建了兩個名為Store_Information 和 Region 的數(shù)據(jù)表。Store_InformationStore_NameSalesDateLos Angeles$1500Jan-10-2000San Diego$250Jan-11-2000Los Angeles$300Jan-12-2000Boston$700Jan-12-2000RegionRegion_NameStore_NameEastBostonEastNew YorkWestLos AngelesWestSan Diego下面,我們就來看一下通過數(shù)據(jù)表的連接實現(xiàn)按不同區(qū)域查詢銷售額。我們注意到在名為 Region 的數(shù)據(jù)表中包含區(qū)域和商店兩個字段信息,而在名為 Store_Information 的數(shù)據(jù)表中則包含每一家商店的銷售信息。因此,為了得到按區(qū)域劃分的銷售信息,我們需要將兩個不同數(shù)據(jù)表的信息結(jié)合在一起進行查詢。通過對上述兩個數(shù)據(jù)表的分析,我們發(fā)現(xiàn)每個數(shù)據(jù)表中都包含一個名為 Store_Name 的字段,因此,我們可以使用如下命令實現(xiàn)查詢目的:SELECT A1.region_name REGION, SUM(A2.Sales) SALESFROM Geography A1, Store_Information A2WHERE A1.store_name = A2.store_nameGROUP BY A1.region_name查詢結(jié)果顯示為:REGION SALESEast $700West $2050說明:上述查詢命令的前兩行用于指定所要查詢的目標(biāo)字段,分別為 Region 數(shù)據(jù)表中的 Region_Name 字段和 Store_Information 數(shù)據(jù)表中 Sales 字段的記錄值總數(shù)。這里,我們設(shè)定兩個字段的別名分別為 REGION 和 SALES,兩個數(shù)據(jù)表的別名分別為 A1和 A2。如果我們只使用字段別名而不設(shè)定數(shù)據(jù)表別名的話,上述SQL 命令的第一行就變成 如下形式:SELECT Region.Region_Name REGION, SUM(Store_Information.Sales) SALES由此我們可以看出有效的使用數(shù)據(jù)表別名,可以極大的簡化對多個數(shù)據(jù)表進行操作的 SQL 命令。上述查詢命令的第3行為 WHERE 從句,正是該從句設(shè)定了兩個數(shù)據(jù)表的連接條件。因為我們希望確保 Region 數(shù)據(jù)表中的 Store_Name 字段能夠與Store_Information 數(shù)據(jù)表中的同名字段相對應(yīng),所以我們規(guī)定兩個字段的記錄值應(yīng)當(dāng)相等。在連接多個數(shù)據(jù)表時,一定要準(zhǔn)確設(shè)定數(shù)據(jù)表的連接條件,如果 WHERE 從句設(shè)定不正確,則可能導(dǎo)致查詢結(jié)果中出現(xiàn)眾多不相關(guān)的數(shù)據(jù)基礎(chǔ)教程SQL 數(shù)據(jù)操作基礎(chǔ)(初級 )1為了建立交互站點,你需要使用數(shù)據(jù)庫來存儲來自訪問者的信息。例如,你要建立一個職業(yè)介紹服務(wù)的站點,你就需要存儲諸如個人簡歷,所感興趣的工作等等這樣的信息。創(chuàng)建動態(tài)網(wǎng)葉也需要使用數(shù)據(jù)庫,如果你想顯示符合來訪者要求的最好的工作,你就需要從數(shù)據(jù)庫中取出這份工作的信息。你將會發(fā)現(xiàn),在許多情況下需要使用數(shù)據(jù)庫。在這一章里,你將學(xué)會怎樣使用“結(jié)構(gòu)化查詢語言” (SQL〕來操作數(shù)據(jù)庫。SQL 語言是數(shù)據(jù)庫的標(biāo)準(zhǔn)語言。在 Active SeverPages 中,無論何時你要訪問一個數(shù)據(jù)庫,你就要使用 SQL 語言。因此,掌握好 SQL 對 ASP 編程是非常重要的。注意:你可以把“SQL”讀作“sequel” ,也可以按單個字母的讀音讀作S-Q-L。 兩種發(fā)音都是正確的,每種發(fā)音各有大量的支持者。在本書里,認(rèn)為“SQL”讀作“sequel” 。通過這一章的學(xué)習(xí),你將理解怎樣用 SQL 實現(xiàn)數(shù)據(jù)庫查詢,你將學(xué)會怎樣使用這種查詢從數(shù)據(jù)表中取出信息,最后,你將學(xué)會怎樣設(shè)計和建立自己的數(shù)據(jù)庫。注意:通過下面幾章對 SQL 的介紹,你將對 SQL 有足夠的了解,從而可以有效地使用 Active Sever Pages。但是,SQL 是一種復(fù)雜的語言,本書不可能包括它的全部細(xì)節(jié)。要全面掌握 SQL 語言,你需要學(xué)習(xí)在 Microsoft SQL Sever 中使用 SQL。你可以到附近的書店去買一本 Microsoft SQL Sever 6.5。SQL 介紹:本書假設(shè)你是在 SQL 操作 Microsoft SQL Sever 的數(shù)據(jù)庫。你也可以用SQL 操作許多其它類型的數(shù)據(jù)庫。SQL 是操作數(shù)據(jù)庫的標(biāo)準(zhǔn)語言。 (事實上,關(guān)于 SQL 語言有一個專門的 ANSI 標(biāo)準(zhǔn)〕注意:不要在你的站點上試圖用 Microsoft Access 代替 Microsoft SQL Sever。SQL Sever 可以同時服務(wù)于許多用戶,如果你希望你的站點有較高的訪問率,MS Access 是不能勝任的。在學(xué)習(xí) SQL 的細(xì)節(jié)之前,你需要理解它的兩大特點。一個特點容易掌握,另一個掌握起來有點困難。第一個特點是所有 SQL 數(shù)據(jù)庫中的數(shù)據(jù)都存儲在表中。一個表由行和列組成。例如,下面這個簡單的表包括 name 和 e-mail address:Name Email Address................................................................Bill Gates billg@microsoft.compresident Clinton president@whitehouse.comStephen Walther swalther@somewhere.com這個表有兩列(列也稱為字段,域〕:Name 和 Email Address。有三行,每一行包含一組數(shù)據(jù)。一行中的數(shù)據(jù)組合在一起稱為一條記錄。無論何時你向表中添加新數(shù)據(jù),你就添加了一條新記錄。一個數(shù)據(jù)表可以有幾十個記錄,也可以有幾千甚至幾十億個記錄。雖然你也許永遠不需要存儲十億個 Email 地址,但知道你能這樣做總是好的,也許有一天你會有這樣的需要。你的數(shù)據(jù)庫很有可能包含幾十個表,所有存儲在你數(shù)據(jù)庫中的信息都被存儲在這些表中。當(dāng)你考慮怎樣把信息存儲在數(shù)據(jù)庫中時,你應(yīng)該考慮怎樣把它們存儲在表中。SQL 的第二個特點有些難于掌握。這種語言被設(shè)計為不允許你按照某種特定的順序來取出記錄,因為這樣做會降低 SQL Sever 取記錄的效率。使用SQL,你只能按查詢條件來讀取記錄。當(dāng)考慮如何從表中取出記錄時,自然會想到按記錄的位置讀取它們。例如,也許你會嘗試通過一個循環(huán),逐個記錄地掃描,來選出特定的記錄。在使用SQL 時,你必須訓(xùn)練自己,不要有這種思路。假如你想選出所有的名字是“Bill Gates”的記錄,如果使用傳統(tǒng)的編程語言,你也許會構(gòu)造一個循環(huán),逐個查看表中的記錄,看名字域是否是“Bill Gates”。這種選擇記錄的方法是可行的,但是效率不高。使用 SQL,你只要說, “選擇所有名字域等于 Bill Gates 的記錄” ,SQL 就會為你選出所有符合條件的記錄。SQL 會確定實現(xiàn)查詢的最佳方法。建設(shè)你想取出表中的前十個記錄。使用傳統(tǒng)的編程語言,你可以做一個循環(huán),取出前十個記錄后結(jié)束循環(huán)。但使用標(biāo)準(zhǔn)的 SQL 查詢,這是不可能實現(xiàn)的。從 SQL 的角度來說,在一個表中不存在前十個記錄這種概念。開始時,當(dāng)你知道你不能用 SQL 實現(xiàn)某些你感覺應(yīng)該能實現(xiàn)的功能,你會受到挫折。你也許會以頭撞墻甚至想寫惡毒的信件給 SQL 的設(shè)計者們。但后來你會認(rèn)識到,SQL 的這個特點不僅不是個限制,反而是其長處。因為 SQL 不根據(jù)位置來讀取記錄,它讀取記錄可以很快。綜上所述,SQL 有兩個特點:所有數(shù)據(jù)存儲在表中,從 SQL 的角度來說,表中的記錄沒有順序。在下一節(jié),你將學(xué)會怎樣用 SQL 從表中選擇特殊的記錄。使用 SQL 從表中取記錄。SQL 的主要功能之一是實現(xiàn)數(shù)據(jù)庫查詢。如果你熟悉 Internet 引擎,那么你已經(jīng)熟悉查詢了。你使用查詢來取得滿足特定條件的信息。例如,如果你想找到有 ASP 信息的全部站點,你可以連接到 Yahoo!并執(zhí)行一個對 Active Sever Pages 的搜索。在你輸入這個查詢后,你會收到一個列表,表中包括所有其描述中包含搜索表達式的站點。多數(shù) Internet 引擎允許邏輯查詢。在邏輯查詢中,你可以包括特殊的運算符如 AND、OR 和 NOT,你使用這些運算符來選擇特定的記錄。例如,你可以用AND 來限制查詢結(jié)果。如果你執(zhí)行一個對 Active Sever Pages AND SQL 的搜索。你將得到其描述中同時包含 Active Sever Pages 和 SQL 的記錄。當(dāng)你需要限制查詢結(jié)果時,你可以使用 AND。如果你需要擴展查詢的結(jié)果,你可以使用邏輯操作符 OR。例如,如果你執(zhí)行一個搜索,搜索所有的其描述中包含 Active Sever Pages OR SQL 的站點,你收到的列表中將包括所有其描述中同時包含兩個表達式或其中任何一個表達式的站點。如果你想從搜索結(jié)果中排除特定的站點,你可以使用 NOT。例如,查詢“Active Sever Pages ”AND NOT “SQL”將返回一個列表,列表中的站點包含 Active Sever Pages,但不包含 SQL。當(dāng)必須排除特定的記錄時,你可以使用 NOT。用 SQL 執(zhí)行的查詢與用 Internet 搜索引擎執(zhí)行的搜索非常相似。當(dāng)你執(zhí)行一個 SQL 查詢時,通過使用包括邏輯運算符的查詢條件,你可以得到一個記錄列表。此時查詢結(jié)果是來自一個或多個表。SQL 查詢的句法非常簡單。假設(shè)有一個名為 email_table 的表,包含名字和地址兩個字段,要得到 Bill Gates 的 e_mail 地址,你可以使用下面的查詢:SELECT email from email_table WHERE name="Bill Gates"當(dāng)這個查詢執(zhí)行時,就從名為 email_table 的表中讀取 Bill Gates 的e_mail 地址。這個簡單的語句包括三部分:■ SELECT 語句的第一部分指名要選取的列。在此例中,只有 email 列被選取。當(dāng)執(zhí)行 時,只顯示 email 列的值 billg@microsoft.com?!?SELECTT 語句的第二部份指明要從哪個(些)表中查詢數(shù)據(jù)。在此例中,要查詢的表名為 email_table?!鲎詈螅琒ELECT 語句的 WHERE 子句指明要選擇滿足什么條件的記錄。在此例中,查詢條件為只有 name 列的值為 Bill Gates 的記錄才被選取。Bill Gates 很有可能擁有不止一個 email 地址。如果表中包含 Bill Gates的多個 email 地址。用上述的 SELECT 語句可以讀取他所有的 email 地址。SELECT 語句從表中取出所有 name 字段值為 Bill Gates 的記錄的 email 字段的值。前面說過,查詢可以在查詢條件中包含邏輯運算符。假如你想讀取 Bill Gates 或 Clinton 總統(tǒng)的所有 email 地址,你可以使用下面的查詢語句:SELECT email FROM email_table WHERE name="Bill Gates" OR name="president Clinton"此例中的查詢條件比前一個復(fù)雜了一點。這個語句從表 email_table 中選出所有 name 列為 Bill Gates 或 president Clinton 的記錄。如果表中含有Bill Gates 或 president Clinton 的多個地址,所有的地址都被讀取。SELECT 語句的結(jié)構(gòu)看起來很直觀。如果你請一個朋友從一個表中為你選擇一組記錄,你也許以非常相似的方式提出你的要求。在 SQL SELECT 語句中,你“SELECT 特定的列 FROM 一個表 WHERE 某些列滿足一個特定的條件” 。下一節(jié)將介紹怎樣執(zhí)行 SQL 查詢來選取記錄。這將幫助你熟悉用 SELECT 語句從表中取數(shù)據(jù)的各種不同方法。SQL 數(shù)據(jù)操作基礎(chǔ)(初級 )2使用 ISQL 執(zhí)行 SELECT 查詢當(dāng)你安裝 SQL Sever 時,你同時安裝了一個叫作 ISQL/w 的應(yīng)用程序。ISQL/w 允許你執(zhí)行交互的 SQL 查詢。在把查詢包括到你的 ASP 網(wǎng)頁中之前,用ISQL/w 對其進行測試是非常有用的。注意:在這本書的第一部份,你學(xué)習(xí)了怎樣安裝和配置 Microsoft SQL Sever。如果沒有安裝 SQL Sever 或者 SQL Sever 不能運行,請參閱第三章“安裝和使用 SQL Sever”。選擇任務(wù)上 SQL Sever 程序組中的 ISQL_w 以啟動該程序。程序啟動時,首先會出現(xiàn)一個對話框,要求輸入服務(wù)器信息和登錄信息。在 Sever 框中,輸入你的 SQL 服務(wù)器的名字。如果服務(wù)器正運行在本地計算機上,服務(wù)器名字就是你計算機的名字。在登錄信息框中,輸入一個登錄帳號和密碼或選擇使用“可信連接” ,然后單擊 Connect 按鈕。 注意:如果你將 SQL Sever 配置為使用完整安全或混合安全,那么你可以使用可信連接。如果你使用標(biāo)準(zhǔn)安全,你則需要提供用戶帳號和密碼。要了解更多信息,參見第三章。如果一切正常,在你單擊連接按鈕后會出現(xiàn)一個查詢窗口。 (如果有異常,請參考第三章) 在執(zhí)行查詢之前,你需要選擇數(shù)據(jù)庫。安裝 SQL Sever 時你已為自己創(chuàng)建了一個數(shù)據(jù)庫,SQL Sever 還有許多系統(tǒng)數(shù)據(jù)庫,如 master,model,msdb,和tempdb。方便的是,SQL Sever 帶有一個特殊的名為 pubs 的例子數(shù)據(jù)庫。庫 pubs中包含供一個虛擬的出版商使用的各個表。文檔中所有的例子程序都是針對這個庫來設(shè)計的。本書中的許多例子也使用這個數(shù)據(jù)庫。在查詢窗口頂部的 DB 下拉框中選擇數(shù)據(jù)庫 pubs,這樣你就選擇了數(shù)據(jù)庫。你所有的查詢都將針對這個庫中的各個表來執(zhí)行?,F(xiàn)在你可以執(zhí)行你的第一個查詢了。這真讓人興奮!你的第一個查詢將針對一個名為 autrors 的表,表中包含所有為某個虛擬出版商工作的作者的相關(guān)數(shù)據(jù)。單擊查詢窗口并輸入以下的語句:SELECT phone FROM authors WHERE au_name="Ringer"輸入完成后,單擊執(zhí)行查詢按鈕(一個綠色三角形,看起來像 VCR 播放鍵) 。單擊此按鈕后,任何出現(xiàn)在查詢窗口中的語句均會被執(zhí)行。查詢窗口會自動變成結(jié)果顯示窗口,你可以看到查詢的結(jié)果。在 SQL Sever 的不同版本中,庫 pubs 中的數(shù)據(jù)會有所不同。對 SQL Sever 6.5來說,將會找到兩條記錄。結(jié)果顯示窗口中應(yīng)顯示如下內(nèi)容:phone……………….801 826_0752801 826_0752(2 row(s) affected)你所執(zhí)行的 SELECT 語句從表 authors 中取出所有名字為 Ringer 的作者的電話號碼。你通過在 WHERE 子句中使用特殊的選擇條件來限制查詢的結(jié)果。你也可以忽略選擇條件,從表中取出所有作者的電話號碼。要做到這一點,單擊Query 標(biāo)簽,返回到查詢窗口,輸入以下的 SELECT 語句:SELECT Phone FROM authors這個查詢執(zhí)行后,會取出表 authors 中的所有電話號碼(沒有特定的順序) 。如果表 authors 中包含一百個電話號碼,會有一百個記錄被取出,如果表中有十億個電話號碼,這十億條記錄都會被取出(這也許需要一些時間) 。表 authrs 的字段包括姓,名字,電話號碼,地址,城市,州和郵政編碼。通過在 SELECT 語句的第一部份指定它們,你可以從表中取出任何一個字段。你可以在一個 SELECT 語句中一次取出多個字段,比如:SELECT au_fname ,au_lname, phone FROM authors這個 SELECT 語句執(zhí)行后,將取出這三個列的所有值。下面是這個查詢的結(jié)果的一個示例(為了節(jié)省紙張,只顯示查詢結(jié)果的一部分,其余記錄用省略號代替):au_fname au_lname phone ………………………………………………………………………….Johnson White 408 496_7223Marjorie Green 415 986_7020Cheryl Carson 415 548_7723Michael O’Leary 408 286_2428… (23 row(s) affected)在 SELECT 語句中,你需要列出多少個字段,你就可以列出多少。不要忘了把字段名用逗號隔開。你也可以用星號(*)從一個表中取出所有的字段。這里有一個使用星號的例子:SELECT * FROM authors這個 SELECT 語句執(zhí)行后,表中的所有字段的值都被取出。你會發(fā)現(xiàn)你將在SQL 查詢中頻繁使用星號。技巧:你可以使用星號來查看一個表的所有列的名字。要做到這一點,只需要在執(zhí)行完 SELECT 語句后看一下查詢結(jié)果的列標(biāo)題。操作多個表到現(xiàn)在為止,你只嘗試了用一句 SQL 查詢從一個表中取出數(shù)據(jù)。你也可以用一個 SELECT 語句同時從多個表中取出數(shù)據(jù),只需在 SELECT 語句的 FROM 從句中列出要從中取出數(shù)據(jù)的表名稱即可:SELECT au_lname ,title FROM authors, titles 這個 SELECT 語句執(zhí)行時,同時從表 authors 和表 titles 中取出數(shù)據(jù)。從表 authors 中取出所有的作者名字,從表 titles 中取出所有的書名。在ISQL/w 程序中執(zhí)行這個查詢,看一下查詢結(jié)果。你會發(fā)現(xiàn)一些奇怪的出乎意料的情況:作者的名字并沒有和它們所著的書相匹配,而是出現(xiàn)了作者名字和書名的所有可能的組合,這也許不是你所希望見到的。出了什么差錯?問題在于你沒有指明這兩個表之間的關(guān)系。你沒有通過任何方式告訴 SQL 如何把表和表關(guān)聯(lián)在一起。由于不知道如何關(guān)聯(lián)兩個表,服務(wù)器只能簡單地返回取自兩個表中的記錄的所有可能組合。要從兩個表中選出有意義的記錄組合,你需要通過建立兩表中字段的關(guān)系來關(guān)聯(lián)兩個表。要做到這一點的途徑之一是創(chuàng)建第三個表,專門用來描述另外兩個表的字段之間的關(guān)系。表 authors 有一個名為 au_id 的字段,包含有每個作者的唯一標(biāo)識。表titles 有一個名為 title_id 的字段,包含每個書名的唯一標(biāo)識。如果你能在字段 au_id 和字段 title_id 之間建立一個關(guān)系,你就可以關(guān)聯(lián)這兩個表。數(shù)據(jù)庫 pubs 中有一個名為 titleauthor 的表,正是用來完成這個工作。表中的每個記錄包括兩個字段,用來把表 titles 和表 authors 關(guān)聯(lián)在一起。下面的SELECT 語句使用了這三個表以得到正確的結(jié)果:SELECT au_name,title FROM authors,titles,titleauthor WHERE authors.au_id=titleauthor.au_idAND titles.title_id=titleauthor.title_id 當(dāng)這個 SELECT 語句執(zhí)行時,每個作者都將與正確的書名相匹配。表titleauthor 指明了表 authors 和表 titles 的關(guān)系,它通過包含分別來自兩個表的各一個字段實現(xiàn)這一點。第三個表的唯一目的是在另外兩個表的字段之間建立關(guān)系。它本身不包含任何附加數(shù)據(jù)。注意在這個例子中字段名是如何書寫的。為了區(qū)別表 authors 和表 titles中相同的字段名 au_id,每個字段名前面都加上了表名前綴和一個句號。名為author.au_id 的字段屬于表 authors,名為 titleauthor.au_id 的字段屬于表titleauthor,兩者不會混淆。通過使用第三個表,你可以在兩個表的字段之間建立各種類型的關(guān)系。例如,一個作者也許寫了許多不同的書,或者一本書也許由許多不同的作者共同完成。當(dāng)兩個表的字段之間有這種“多對多”的關(guān)系時,你需要使用第三個表來指明這種關(guān)系。但是,在許多情況下,兩個表之間的關(guān)系并不復(fù)雜。比如你需要指明表titles 和表 publishers 之間的關(guān)系。因為一個書名不可能與多個出版商相匹配,你不需要通過第三個表來指明這兩個表之間的關(guān)系。要指明表 titles 和表publishers 之間的關(guān)系,你只要讓這兩個表有一個公共的字段就可以了。在數(shù)據(jù)庫 pubs 中,表 titles 和表 publishers 都有一個名為 pub_id 的字段。如果你想得到書名及其出版商的一個列表,你可以使用如下的語句:SELECT title,pub_name FROM titles,publishersWHERE titles.pub_id=publishers.pub_id當(dāng)然,如果一本書是由兩個出版商聯(lián)合出版的,那么你需要第三個表來代表這種關(guān)系。通常,當(dāng)你予先知道兩個表的字段間存在“多對多”關(guān)系時,就使用第三個表來關(guān)聯(lián)這兩個表。反之,如果兩個表的字段間只有“一對一”或“一對多”關(guān)系,你可以使用公共字段來關(guān)聯(lián)它門。SQL 數(shù)據(jù)操作基礎(chǔ)(初級 )3操作字段通常,當(dāng)你從一個表中取出字段值時,該值與創(chuàng)建該表時所定義的字段名聯(lián)系在一起。如果你從表 authors 中選擇所有的作者名字,所有的值將會與字段名 au_lname 相聯(lián)系。- 1.請仔細(xì)閱讀文檔,確保文檔完整性,對于不預(yù)覽、不比對內(nèi)容而直接下載帶來的問題本站不予受理。
- 2.下載的文檔,不會出現(xiàn)我們的網(wǎng)址水印。
- 3、該文檔所得收入(下載+內(nèi)容+預(yù)覽)歸上傳者、原創(chuàng)作者;如果您是本文檔原作者,請點此認(rèn)領(lǐng)!既往收益都?xì)w您。
下載文檔到電腦,查找使用更方便
10 積分
下載 |
- 配套講稿:
如PPT文件的首頁顯示word圖標(biāo),表示該PPT已包含配套word講稿。雙擊word圖標(biāo)可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設(shè)計者僅對作品中獨創(chuàng)性部分享有著作權(quán)。
- 關(guān) 鍵 詞:
- SQL 非常 全面 入門教程
鏈接地址:http://m.kudomayuko.com/p-324281.html