ASP.NET中的資料來源控制項的緩衝

來源:互聯網
上載者:User

部落格園中系列文章:溫故知新ASP.NET 2.0(C#)(4) - 緩衝&SqlCacheDependency中有一段關於資料來源控制項的Sql緩衝的講解,如下:

DataSource控制項設定如下屬性:EnableCaching="True" SqlCacheDependency="CacheTest:CacheTest" CacheDuration="Infinite"

如果是SqlServer2005則改成SqlDependency="CommandNotification"

注意設定檔中的配置

我測試了一下,總結了兩點:

1、只要資料來源控制項採用如下配置:

Code
                <asp:ObjectDataSource ID="ObjectDataSource1" runat="server" 
                SelectMethod="GetCacheTests"
                TypeName="SqlCache.BLL.CacheTest" 
                EnableCaching="true" 
                CacheDuration="10" 
                SqlCacheDependency="CommandNotification">
                </asp:ObjectDataSource>

 

無論是sql2000或2005、2008,都不需要額外做任何事情,設定檔也不需要寫任何東西。

2、如果資料來源控制項採用如下配置:

Code
                <asp:ObjectDataSource ID="ObjectDataSource1" runat="server" 
                SelectMethod="GetCacheTests"
                TypeName="SqlCache.BLL.CacheTest" 
                EnableCaching="true" 
                CacheDuration="10" 
                SqlCacheDependency="CacheTest:CacheTest">
                </asp:ObjectDataSource>
                      或                   
                  <asp:ObjectDataSource ID="ObjectDataSource1" runat="server" 
                SelectMethod="GetCacheTests"
                TypeName="SqlCache.BLL.CacheTest" 
                EnableCaching="true" 
                CacheDuration="Infinite" 
                SqlCacheDependency="CacheTest:CacheTest">
                </asp:ObjectDataSource>

 

無論是sql2000或2005、2008,設定檔中都要這樣寫:

Code
          <caching>
              <sqlCacheDependency enabled="true" pollTime="10000">
                  <databases>
                      <add name="CacheTest" connectionStringName="MsSqlConnString" />
                  </databases>
              </sqlCacheDependency>
              //如果是SqlServer2005的話,則只需如下設定,因為SqlServer支援基於通知的緩衝失效
              //<sqlCacheDependency enabled="true" />
                          //第7行的話是錯誤的。
         </caching>

 

而且還要使用aspnet_regsql.exe工具,通知數據庫。

我的測試代碼:SqlCache.rar

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.