在ASP中使用SQL語句之7:ORDER BY
發(fā)表時間:2023-08-13 來源:明輝站整理相關軟件相關文章人氣:
[摘要]從Access數(shù)據(jù)庫中選取記錄有件最令人喪氣的事情,它們是以怎樣的順序輸入到數(shù)據(jù)庫內(nèi)就按照怎樣的順序出來。就算你在Access環(huán)境內(nèi)采用Sort By來改變記錄視圖,數(shù)據(jù)表內(nèi)的記錄順序也并沒有發(fā)生改...
從Access數(shù)據(jù)庫中選取記錄有件最令人喪氣的事情,它們是以怎樣的順序輸入到數(shù)據(jù)庫內(nèi)就按照怎樣的順序出來。就算你在Access環(huán)境內(nèi)采用Sort By來改變記錄視圖,數(shù)據(jù)表內(nèi)的記錄順序也并沒有發(fā)生改變。
如果你正在使用ASPrecordset在網(wǎng)頁上寫出記錄,那么你或許知道亂紛紛的順序是多令人痛苦的事。但是你可能不得不經(jīng)常得面對這一問題,因為并不存在什么簡單方便的解決方案。好在ORDER BY 可以簡化這一難題。
為了對你的結(jié)果排序,只要在SELECT語句末尾加上ORDER BY,然后指定你需要排序的參照列即可。因此,如果你想要根據(jù)顧客的姓氏對Customers表排序,那么你可以編寫如下的查詢語句:
SQL = "SELECT c_lastname, c_firstname, c_email FROM Customers ORDER BY c_lastname"
這樣,只要你建立了recordset而且開始把結(jié)果寫到屏幕上,你就會看見數(shù)據(jù)按照字母順序排列起來了。
多級排序
其實不僅僅可以在SQL語句中進行一級排序。實際上,在很多情況下,你可能會希望指定兩到三級深度的數(shù)據(jù)排序。假設你有以下數(shù)據(jù)表,其內(nèi)容如下所示: [image003.gif]
先前采用的單級ORDER BY 排序是按下面的順序取出數(shù)據(jù)的:
Absurdly Assured
[email protected]
Absolutely Assured
[email protected]
Crazed Coder
[email protected]
Loosely Fringe
[email protected]
Lunatic Fringe
[email protected]
Hands On
[email protected]
顯然ORDER BY 起了應有的作用。在實際的表結(jié)構下,Absurdly Assured 是最后的條目,但它排在檢索結(jié)果的最頂端。Hands On記錄排最后因為 O 在以上列表中排在字母表最后。顯然,Absolutely按照字母表最好排在Absurdly之前。為此,你需要采取第2級ORDER BY 排序標準,參照第2列進行排序:
SQL = "SELECT c_lastname, c_firstname, c_email FROM Customers ORDER BY
c_lastname, c_firstname"
其結(jié)果將首先按照c_lastname 列排序然后按照c_firstname 列排序。假如你的數(shù)據(jù)表包含的記錄比較多,仔細設計排序會令輸出結(jié)果編排更為合理。
投入使用
如果你同大多數(shù)程序員一樣喜歡自己動手編代碼,沉湎于掌握新技術的狂熱之中。何不從ASP的冗長編碼中轉(zhuǎn)過頭來嘗試一下SQL編碼呢?下面我們將就ASP編程時常見的問題以及如何在ASP中高效地利用SQL語句做一番探討。