程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> .Net 2.0 緩存使用

.Net 2.0 緩存使用

編輯:.NET實例教程
在訪問量大,但更新較少的網站中使用緩存,可以大大提高運行效率;加上.Net 2.0提供的緩存依賴機制,我們可以很方便的對緩存進行管理更新;以下是本人學習的一點心得體會,希望能夠起到拋磚引玉的作用。

建立緩存依賴:

 


        /**//// <summary>
        /// 建立緩存依賴項
        /// </summary>
        /// <returns></returns>
        private AggregateCacheDependency TableDependency()
        {
            AggregateCacheDependency dependency = new AggregateCacheDependency();
            dependency.Add(new SqlCacheDependency("MSPetShop4", "表名稱"));

            return dependency;
        }

 

一個非常簡單的方法,首先我們先看看兩個.Net 2.0新增的兩個類:

AggregateCacheDependency在System.Web.Caching命名空間中,AggregateCacheDependency主要作用是用於組合 ASP.Net 應用程序的 Cache 對象中存儲的項和 CacheDependency 對象的數組之間的多個依賴項。

SqlCacheDependency也存在於System.Web.Caching命名空間中,這個類用於建立ASP.Net應用程序的Cache對象中存儲的項和特定SQL Server數據庫表之間的聯系。

SqlCacheDependency是如何建立Cache對象中存儲的項和特定SQL Server數據庫表之間的聯系的呢?看一下Web.Config配置文件就一目了然了。

<?XML version="1.0"?>
<configuration XMLns="http://schemas.microsoft.com/.NetConfiguration/v2.0">
 <connectionStrings>
  <add name="LocalConnString" connectionString="Server=(Local);uid=sa;pwd=123456;DataBase=MSPetShop4"/>
 </connectionStrings>
 <system.web>
  <caching>
   <sqlCacheDependency enabled="true" pollTime="10000">
    <databases>
     <add name="MSPetShop4" connectionStringName="LocalConnString" pollTime="10000"/>
    </databases>
   </sqlCacheDependency>
  </caching>
  <compilation debug="true"/>
        </system.web>
</configuration>


配置節<databases><add name="MSPetShop4" connectionStringName="LocalConnString" pollTime="10000"/></databases>中配置了數據庫信息,SqlCacheDependency類會自動完成對此配置節信息的讀取以建立和數據庫之間的聯系。(注意)name="MSPetShop4"必須和new

SqlCacheDependency("MSPetShop4", "表名稱")中的數據庫名稱相一致。更多的配置信息可以查看(MSDN幫助文檔)。

使數據庫支持SqlCacheDependency特性:

要使得7.0或者2000版本的SQL Server支持SqlCacheDependency特性,需要對數據庫服務器執行相關的配置步驟。有兩種方法配置SQL Server:

使用ASPnet_regsql命令行工具,或者使用SqlCacheDependencyAdmin類。

ASPnet_regsql工具位於Windows\Microsoft.Net\Framework\[版本]文件夾中,如果要配置SqlCacheDependency,則需要以命令行的方式執行。

以下是該工具的命令參數說明:
-?  顯示該工具的幫助功能;
-S  後接的參數為數據庫服務器的名稱或者IP地址;
-U  後接的參數為數據庫的登陸用戶名;
-P  後接的參數為數據庫的登陸密碼;
-E  當使用Windows集成驗證時,使用該功能;
-d  後接參數為對哪一個數據庫采用SqlCacheDependency功能;
-t  後接參數為對哪一個表采用SqlC

acheDependency功能;
-ed  允許對數據庫使用SqlCacheDependency功能;
-dd  禁止對數據庫采用SqlCacheDependency功能;
-et  允許對數據表采用SqlCacheDependency功能;
-dt  禁止對數據表采用SqlCacheDependency功能;
-lt  列出當前數據庫中有哪些表已經采用sqlcachedependency功能。

比如在petshop4.0的數據庫中使用SqlCacheDependency特性:ASPnet_regsql -S localhost -E -d MSPetShop4 -ed

以上面的命令為例,說明將對名為MSPetShop4的數據庫采用SqlCacheDependency功能,且SQL Server采用了Windows集成驗證方式。我們還可以

對相關的數據表執行ASPnet_regsql命令,如:
ASPnet_regsql -S localhost -E -d MSPetShop4 -t Item -et
ASPnet_regsql -S localhost -E -d MSPetShop4 -t Product -et
ASPnet_regsql -S localhost -E -d MSPetShop4 -t Category -et

最後為使用緩存:
          


        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                string key = "TableCache"; //緩存名稱
                DataSet data = (DataSet)HttpRuntime.Cache[key]; //獲取緩存

                // 判斷緩存數據為空
                if (data == null)
                {
                    // 獲取數據
                    data = GetDataSource(); 

                    // 創建緩存依賴
                &nbs
p;   AggregateCacheDependency cd = TableDependency();

                    // 創建緩存
                    HttpRuntime.Cache.Add(key, data, cd, DateTime.Now.AddHours(1), Cache.NoSlidingExpiration, 

CacheItemPriority.High, null);
                }

                GridVIEw1.DataSource = data; //綁定數據
                GridVIEw1.DataBind();
            }
        }

 


獲取數據源的方法,結合實際使用做修改。

 


        private DataSet GetDataSource()
        {
            string ConnectionStringLocal = ConfigurationManager.ConnectionStrings["LocalConnString"].ConnectionString;
            SqlConnection connPubs = new SqlConnection(ConnectionStringLocal);
            SqlDataAdapter dad = new SqlDataAdapter("SELECT TOP 50 * FROM Product", connPubs);
            DataSet ds = new DataSet();
            dad.Fill(ds);

            return ds;
        }

就這麼簡單:) 



  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved