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
      ...
   End If

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

   第二,如ADO__05.asp所示,在迴圈外面建立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所示,在每一個迴圈內把串連串賦給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


   就象我們可以猜想到的一樣,在迴圈內建立和拆除連線物件是效率最差的方法。不過,令人驚異的是,在迴圈內直接把串連串賦給ActiveConnection屬性只比共用單個連線物件稍微慢了一點。

   儘管如此,第三規則應該為:

l    同一頁面內用到多個記錄集時,建立單一的連線物件並通過ActiveConnection屬性共用它。



相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.