明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

asp性能測試第二局部(轉(zhuǎn))(5)

[摘要]五、使用記錄集時是否應(yīng)該創(chuàng)建單獨的連接對象? 要正確地回答這個問題,我們必須分析兩種不同條件下的測試:第一,頁面只有一個數(shù)據(jù)庫事務(wù);第二,頁面有多個數(shù)據(jù)庫事務(wù)。 在前例中,我們創(chuàng)建了一個單獨的Connection對象并將它賦給Recordset的ActiveConnection屬性。然而,如A...

五、使用記錄集時是否應(yīng)該創(chuàng)建單獨的連接對象?
要正確地回答這個問題,我們必須分析兩種不同條件下的測試:第一,頁面只有一個數(shù)據(jù)庫事務(wù);第二,頁面有多個數(shù)據(jù)庫事務(wù)。

在前例中,我們創(chuàng)建了一個單獨的Connection對象并將它賦給Recordset的ActiveConnection屬性。然而,如ADO__03.asp所示,我們也可以直接把連接串賦給ActiveConnection屬性,在腳本中初始化和配置Connection對象這一額外的步驟可以省去。
objRS.ActiveConnection = Application("Conn")

雖然Recordset對象仍舊要創(chuàng)建一個連接,但此時的創(chuàng)建是在高度優(yōu)化的條件下進(jìn)行的。因此,與上一次測試相比,頁面開銷又下降了23%,而且如預(yù)期的一樣,單個記錄的顯示時間沒有實質(zhì)的變化。

因此,我們的第二個規(guī)則如下:

如果只使用一個記錄集,直接把連接串賦給ActiveConnection屬性。
接下來我們檢查頁面用到多個記錄集時,上述規(guī)則是否仍舊有效。為測試這種情形,我們引入一個FOR循環(huán)將前例重復(fù)10次。在這個測試中,我們將研究三種變化:

第一,如ADO__04.asp所示,在每一個循環(huán)中建立和拆除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
...
End If

objRS.Close
Set objRS = Nothing
objConn.Close
Set objConn = Nothing

Next




第二,如ADO__05.asp所示,在循環(huán)外面創(chuàng)建Connection對象,所有記錄集共享該對象:
Set objConn = Server.CreateObject("ADODB.Connection")
objConn.Open Application("Conn")

Dim i
For i = 1 to 10
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
...
End If

objRS.Close
Set objRS = Nothing

Next
objConn.Close
Set objConn = Nothing

第三,如ADO__06.asp所示,在每一個循環(huán)內(nèi)把連接串賦給ActiveConnection屬性:
Dim i
For i = 1 to 10

Set objRS = Server.CreateObject("ADODB.Recordset")
objRS.ActiveConnection = Application("Conn")
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
...
End If

objRS.Close
Set objRS = Nothing
Next

就象我們可以猜想到的一樣,在循環(huán)內(nèi)創(chuàng)建和拆除連接對象是效率最差的方法。不過,令人驚異的是,在循環(huán)內(nèi)直接把連接串賦給ActiveConnection屬性只比共享單個連接對象稍微慢了一點。

盡管如此,第三規(guī)則應(yīng)該為:

同一頁面內(nèi)用到多個記錄集時,創(chuàng)建單一的連接對象并通過ActiveConnection屬性共享它。
(出處:熱點網(wǎng)絡(luò))