為了建立交互站點,你需要使用數(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 Sever Pages 中,無論何時你要訪問一個數(shù)據(jù)庫,你就要使用SQL語言。因此,掌握好SQL對asp編程是非常重要的。
注意: 通過下面幾章對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)〕
在學(xué)習(xí)SQL的細(xì)節(jié)之前,你需要理解它的兩大特點。一個特點容易掌握,另一個掌握起來有點困難。 第一個特點是所有SQL數(shù)據(jù)庫中的數(shù)據(jù)都存儲在表中。一個表由行和列組成。例如,下面這個簡單的表包括name 和e-mail address: Name Email Address ................................................................ Bill Gates billg@microsoft.com PResident Clinton president@whitehouse.com Stephen Walther swalther@somewhere.com 這個表有兩列(列也稱為字段,域〕:Name和Email Address。有三行,每一行包含一組數(shù)據(jù)。一行中的數(shù)據(jù)組合在一起稱為一條記錄。 無論何時你向表中添加新數(shù)據(jù),你就添加了一條新記錄。一個數(shù)據(jù)表可以有幾十個記錄,也可以有幾千甚至幾十億個記錄。雖然你也許永遠(yuǎn)不需要存儲十億個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的搜索。在你輸入這個查詢后,你會收到一個列表,表中包括所有其描述中包含搜索表達(dá)式的站點。 多數(shù)Internet 引擎允許邏輯查詢。在邏輯查詢中,你可以包括特殊的運算符如AND、OR和NOT,你使用這些運算符來選擇特定的記錄。例如,你可以用AND來限制查詢結(jié)果。如果你執(zhí)行一個對Active Sever Pages AND SQL的搜索。你將得到其描述中同時包含Active Sever Pages 和SQL的記錄。當(dāng)你需要限制查詢結(jié)果時,你可以使用AND。 如果你需要擴(kuò)展查詢的結(jié)果,你可以使用邏輯操作符OR。例如,如果你執(zhí)行一個搜索,搜索所有的其描述中包含Active Sever Pages OR SQL的站點,你收到的列表中將包括所有其描述中同時包含兩個表達(dá)式或其中任何一個表達(dá)式的站點。 如果你想從搜索結(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"
輸入完成后,單擊執(zhí)行查詢按鈕(一個綠色三角形,看起來像VCR播放鍵)。單擊此按鈕后,任何出現(xiàn)在查詢窗口中的語句均會被執(zhí)行。查詢窗口會自動變成結(jié)果顯示窗口,你可以看到查詢的結(jié)果(見圖10.3)。 你看到的查詢結(jié)果也許與圖10.3所示的不同。在SQL Sever的不同版本中,庫pubs中的數(shù)據(jù)會有所不同。對SQL Sever 6.5來說,將會找到兩條記錄。結(jié)果顯示窗口中應(yīng)顯示如下內(nèi)容:
操作字段 通常,當(dāng)你從一個表中取出字段值時,該值與創(chuàng)建該表時所定義的字段名聯(lián)系在一起。如果你從表authors中選擇所有的作者名字,所有的值將會與字段名au_lname相聯(lián)系。但是在某些情況下,你需要對字段名進(jìn)行操作。在SELECT語句中,你可以在缺省字段名后面僅跟一個新名字來取代它。例如,可以用一個更直觀易讀的名字Author Last Name來代替字段名au_lname:
SELECT au_lname "Author Last Name" FROM authors
當(dāng)這個SELECT語句執(zhí)行時,來自字段au_lname的值會與“Author Last Name”相聯(lián)系。查詢結(jié)果可能是這樣:
Author Last Name …………………………………………………………………….. White Green Carson O’Leary Straight … (23 row(s) affected)
注意字段標(biāo)題不再是au_lname,而是被Author Last Name所取代。 你也可以通過執(zhí)行運算,來操作從一個表返回的字段值。例如,如果你想把表titles中的所有書的價格加倍,你可以使用下面的SELECT語句:
CREATE TABLE addresses (street VARCHAR(60) NULL, city VARCHAR(40) NULL, state VARCHAR(20) NULL zip VARCHAR(20) NULL, country VARCHAR(30) DEFAULT ‘USA’)