• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    ASP程序性能測試報告

    發布: 2007-5-22 15:01 | 作者: 網絡轉載 | 來源: 網絡轉載 | 查看: 176次 | 進入軟件測試論壇討論

    領測軟件測試網

    四、是否應該通過包含引用ADOVBS.inc?

       Microsoft提供的ADOVBS.inc包含了270行代碼,這些代碼定義了大多數的ADO屬性常量。我們這個示例只從ADOVBS.inc引用了2個常量。因此本次測試(ADO__02.asp)中我們刪除了包含文件引用,設置屬性時直接使用相應的數值。

    objRS.CursorType = 0?' adOpenForwardOnly
    objRS.LockType = 1' adLockReadOnly


       可以看到頁面開銷下降了23%。該值并不影響單個記錄的提取和顯示時間,因為這里的變化不會影響循環內的記錄集操作。有多種方法可以解決ADOVBS.inc的引用問題。我們建議將ADOVBS.inc文件作為參考,設置時通過注釋加以說明。請記住,正如第一部分所指出的,適度地運用注釋對代碼的效率影響極小。另外一種方法是將那些需要用到的常量從ADOVBS.inc文件拷貝到頁面內。

       還有一個解決該問題的好方法,這就是通過鏈接ADO類型庫使得所有的ADO常量直接可用。把下面的代碼加入Global.asa文件,即可直接訪問所有的ADO常量:

    < !--METADATA TYPE="typelib"
    FILE="C:Program FilesCommon FilesSYSTEMADOmsado15.dll"
    NAME="ADODB Type Library" -- >

    或者:

    < !--METADATA TYPE="typelib"
    UUID="00000205-0000-0010-8000-00AA006D2EA4"
    NAME="ADODB Type Library" -- >

       因此,我們的第一條規則為:

    l避免包含ADOVBS.inc文件,通過其他方法訪問和使用ADO常量。
    五、使用記錄集時是否應該創建單獨的連接對象?

       要正確地回答這個問題,我們必須分析兩種不同條件下的測試:第一,頁面只有一個數據庫事務;第二,頁面有多個數據庫事務。

       在前例中,我們創建了一個單獨的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屬性共享它。

    文章來源于領測軟件測試網 http://www.kjueaiud.com/

    53/5<12345>

    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>