標籤:des style http io color ar os 使用 for
ASP有一個最重要的功能,就是它可以讓你非常輕鬆地串連資料庫。通常都是和一個Access或者一個SQL資料庫相連。因為Access是最容易起步的,同時,在你的機器上也許已經都裝有Access了,所以,在下面的例子中,我們都將使用Access來做例子。一旦你學習了ASP和Access資料庫連接的核心技術方法,當你開始使用SQL server的時候,你就會發現,兩者所需要的關鍵技術是基本相同的。
當你要串連資料庫的時候,你需要在伺服器上將這個資料庫開啟。你可以通過使用資料來源名(DSN)或者通過在你的指令碼語言中直接使用一個DSN-less串連的方法來串連和開啟資料庫。
建立一個資料來源名(DSN)
你可以通過在控制台中給你的資料庫建立一個系統DSN來使你的資料庫可以在ASP中串連使用。你可以在你的本機電腦上建立若干個DSN,每個DSN對應你使用的不同的資料庫。在建立完DSN之後,你就可以在你的本機伺服器上測試你的頁面了。如果你的網站是由
ISP提供服務的,並且這個ISP支援ASP,那麼很有可能它就會提供一個GUI介面,來給你的資料庫建立一個DSN。
在Windows 95/98/NT中,開啟控制台(開始菜單->設定->控制台),雙擊ODBC進入。
選擇系統DSN,點擊Add。
選擇“Microsoft Access Driver”,點擊結束。
填寫資料來源名。這是你給你的資料庫起的名字,所以和一個alias是同樣的操作。
在資料庫選擇中點擊選擇按鈕,瀏覽系統中你建立的Access資料庫所存放的位置。
點擊OK
現在,新的DSN現在就會在系統DSN中顯示,並且可以在你的本機伺服器上使用了。
串連資料庫
讓我們建立一個DSN-less串連,並且看看是如何串連資料庫的。當你建立一個DSN的時候,你就已經儲存了關於這個資料庫的一些資訊,所以你不需要在每次需要使用一些資訊的時候重複它們,這些資訊如:資料庫類型、名稱、存放地點和可選性、使用者和密碼。
要建立一個DSN-less串連,你就需要提供同樣的資訊。下面這個例子就顯示了如何給一個叫products的資料庫建立一個DSN-less串連:
<%
StrConnect = "Driver={Microsoft Access Driver (*.mdb)}; DBQ=C:\\\\\\\\db\\\\\\\\products.mdb"
Set objConn = Server.CreateObject ("ADODB.Connection")
objConn.OpenStrConnect
%>
第二行定義了資料庫的驅動和實體路徑。為了要使用一個DSN-less串連,你就需要知道實際的檔案存放地點(絕對路徑)。Server.MapPath給任何一個使用主機服務的人提供了一個簡單的工作環境來尋找出那些難於查到的實際訪問路徑。
如果我們已經建立了一個系統DSN,並命名為products,則串連碼應該為:
<%
Set objConn = Server.CreateObject ("ADODB.Connection")
objConn.Open "products"
%>
現在,資料庫就已經開啟了,那麼你可以做些什麼呢?第一件事情當然就是閱讀資料庫中的一系列記錄,並將它們放到你的頁面中去。但是,在這之前,你需要一個recordset。
Recordset
一個recordset是儲存在特殊資料庫表上的所有資訊。所以,當你開啟這個recordset的時候,表中所有的行和列的內容都是可訪問的。你需要開啟這個recordeset,正如你需要開啟資料庫連接一樣。它們的命令是相似的:
Set objRec = Server.CreateObject ("ADODB.Recordset")
objRec.Open "downloadable", strConnect, 0,1,2
這個語句就建立了一個名為downloadable表的recordset(objRec),這個表在products資料庫的strConnect中定義。使用Recordset open, 我們就可以迴圈瀏覽這個表,並且可以將它的所有內容都顯示到螢幕上。或者,我們可以測試特定欄位的內容,也可以只將我們關注的內容寫到螢幕上去。
每一列代表一個欄位。所以,如果資料庫表如下所示:
Product ID |
SKU |
Name |
File |
1 |
PR12345 |
Product A |
install_a.exe |
2 |
PR12346 |
Product B |
Install_b.exe |
那麼,我們就有如下欄位的內容:ProductID, SKU, Name, 和File。你的表很可能會有許多額外的欄位內容,可能包含很多東西,如價格或者是產品(商品)描述。但是這個可以給你提供最基本的資料庫表的概念。
填寫recordset內容
使用recordset是非常容易的一件事情。如果你想要迴圈瀏覽資料庫,並將所有的資訊都列印到螢幕上顯示,你可以按照下面來操作:
While NOT objRec.EOF
\\\\\\\‘ says to do this as long as we haven\\\\\\\‘t reached the end of the file
Response.WriteobjRec("ProductID") & ", "
Response.WriteobjRec("SKU") & ", "
Response.WriteobjRec("Name") & ", "
Response.WriteobjRec("File") & "<BR>"
objRec.MoveNext
Wend ;
即使你沒有如此使用過loop,你仍然可以通過閱讀這個代碼來將資訊寫到comma-delimited字串裡,並且當資料庫表中建立了一個新行的時候,就重新建立一個新的行,來記錄表中的那一行。你可以使用同樣的方法將資料寫到HTML表格中去。通過使用Response.Write添加你的TABLE標籤,需要記住以下幾點:
你的HTML 標籤和引號中的內容。[上海治療陽痿醫院]
如果你的標籤或者內容使用了引號,注意使用雙引號:
<FONT SIZE=""+2"">.
使用&來串連變數和HTML/內容資訊
選擇recordset中的欄位
假設我們的products資料庫同樣包含一個叫OS的欄位,假設這個欄位是一個平台分界符。同樣,讓我們假設儲存在這個欄位的資料只能是如下的資料:Windows NT, Windows 95, Windows 98, Windows, Mac, Unix, 或者 Linux。
下面,我們就可以確認我們需要將哪個欄位列印到螢幕上,而要忽略哪些那些欄位。或者,我們可以選擇哪些欄位用一種格式,而另外的欄位用其它的格式,如,使用不同的顏色。
使用一個簡單的If...,迴圈就可以給我們提供更多的資料庫控制權利。首先讓我們來列印有關Windows NT產品的記錄:
<TABLE BORDER=0 WIDTH=600>
<TR><TD COLSPAN=4 ALIGN=CENTER><FONT SIZE="+1"<<B>Windows NT Products</B></FONT></TD></TR>
<%
While NOT objRec.EOF
If objRec("OS") = "Windows NT" THEN \\\\\\\‘ specifies the criteria
Response.Write "<TR><TD BGCOLOR=""#FFFF66"">" & objRec("ProductID") & "</TD>"
Response.Write "<TD>" & objRec("SKU") & "</TD>"
Response.Write "<TD>" & objRec("Name") & "</TD>"
Response.Write "<TD>" & objRec("File") & "</TD></TR>"
end if
objRec.MoveNext
Wend
%>
</TABLE>
添加一個記錄
一旦你開始使用recordset和ASP了,你就會十分希望能夠通過網路將資料添加到資料庫中去。新增內容是非常重要的,如,當你需要你的網頁瀏覽者留下它們的觀點和看法,或者,當你想要進行管理更新的時候。
下面的代碼開啟了一個recordset,這個recordset是有關一個有著書本和它們作者名字的資料庫表格。你可能曾經看到過這個,但是這次,最後三個說明書定義的指標類型是不同的:adOpenStatic, adLockOptimistic, adCmdTable:
<% \\\\\\\‘ database connection already made; code not shown here
Set objRec = Server.CreateObject ("ADODB.Recordset")
objRec.Open "books", bookdb, adOpenStatic, adLockOptimistic, adCmdTable
%>
(如果你沒有使用adovbs.inc的複製檔案,第三行應該為:objRec.Open "books", bookdb, 3,3,2).
recordset現在就準備好接收資料了,你只需要告訴它添加什麼。在這個情況下,假設我們從表格中取出變數:strBookTitle和strBookAuthor。我們的table, books有兩個欄位,稱作Title 和 Author,所以我們可以通過使用下面的語句來添加一個新的記錄:
<%
objRec.AddNew
ObjRec("Title") = strBookTitle
objRec("Author") = strBookAuthor
objRec.Update
%>
strBookTitle和strBookAuthor代表值,通常被使用者訪問。如果你只是想測試add功能,你可以給title和author添加一個變數――只是需要記住使用引號。在你第一次使用它的時候,你可能會立即開啟你的資料庫,以確保更新的發生。
Recordset類型
在顯示的objRec.Open例子中,你會發現在末尾有0,1,2的字樣。這些數字代表不同的指標類型。你是用的類型依賴於你將使用它來幹什麼。例如,如果你不需要修改或增加任何的記錄,你可以使用一個Lock類型。而當你計劃要修改或者更新資料庫的時候,你所選擇的類型就會不同。
0,1,2 實際上代表:
adOpenForwardOnly, adLockReadOnly, adCmdTable
當然,如果在你的伺服器上已經有了adovbs.inc的備份,那麼,你也可以不使用數字,直接使用這些單詞。adovbs.inc 包括了這三個常量和其它常量的一個列表。
在ASP中使用資料庫