ASP程式效能測試報告(四)
來源:互聯網
上載者:User
五、使用記錄集時是否應該建立單獨的連線物件?
要正確地回答這個問題,我們必須分析兩種不同條件下的測試:第一,頁面只有一個資料庫事務;第二,頁面有多個資料庫事務。
在前例中,我們建立了一個單獨的Connection對象並將它賦給Recordset的ActiveConnection屬性。然而,如ADO__03.asp所示,我們也可以直接把串連串賦給ActiveConnection屬性,在指令碼中初始化和配置Connection對象這一額外的步驟可以省去。
objRS.ActiveConnection = Application("Conn")
雖然Recordset對象仍舊要建立一個串連,但此時的建立是在高度最佳化的條件下進行的。因此,與上一次測試相比,頁面開銷又下降了23%,而且如預期的一樣,單個記錄的顯示時間沒有實質的變化。
因此,我們的第二個規則如下:
l 如果只使用一個記錄集,直接把串連串賦給ActiveConnection屬性。
接下來我們檢查頁面用到多個記錄集時,上述規則是否仍舊有效。為測試這種情形,我們引入一個FOR迴圈將前例重複10次。在這個測試中,我們將研究三種變化:
第一,如ADO__04.asp所示,在每一個迴圈中建立和拆除Connection對象:
Dim i
For i = 1 to 10
Set objConn = Server.CreateObject("ADODB.Connection")
objConn.Open Application("Conn")
Set objRS = Server.CreateObject("ADODB.Recordset")
objRS.ActiveConnection = objConn
objRS.CursorType = 0 'adOpenForwardOnly
objRS.LockType = 1 'adLockReadOnly
objRS.Open Application("SQL")
If objRS.EOF Then
Response.Write("No Records Found")
Else
'write headings
...
'write data