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