爲了更快的讀取數據,咱們通常會把經常使用到的數據加載到Cache中
在.NET中,Cache的存在能夠依賴多中方式,主要用到HttpContext.Current.Cache類
在這裏,我主要寫幾種依賴方式
1:不依賴任何條件
HttpContext.Current.Cache.Insert(string cacheName,object obj)
理論上是Cache會永久保存,可是當服務器從新啓動,內存緊張的時候也會丟失.
2:HttpContext.Current.Cache.Insert(string key, object value, CacheDependency dependencies, DateTime absoluteExpiration, TimeSpan slidingExpiration);
//CacheDependency緩存依賴項,absoluteExpiration絕對過時時間,slidingExpiration最後一次訪問的時間隔
//咱們主要講兩種Cache依賴
2.1:文件依賴,so simple//只要文件改動,Cache移出
HttpContext.Current.Cache.Insert(cacheName,ojb, new System.Web.Caching.CacheDependency(FilePath));
2.2:SqlServer數據庫依賴//我這裏是SQL2005
首先看數據庫通知是否可用,記得必定要開啓通知
Select DATABASEpRoPERTYEX('數據庫名','IsBrokerEnabled');若是值爲1表示可用
alter database Game176Admin set ENABLE_BROKER ;//開啓
alter database Game176Admin set DISABLE_BROKER;//關閉
在Global.asax文件中,咱們在應用程序開始和結束時要作一些事情
void Application_Start(object sender, EventArgs e)
{
// 在應用程序啓動時運行的代碼
try
{
System.Data.SqlClient.SqlDependency.Start(string strCon);//開啓
}
catch { }
}
void Application_End(object sender, EventArgs e)
{
// 在應用程序關閉時運行的代碼
try
{
System.Data.SqlClient.SqlDependency.Stop(string strCon);
}
catch { }
}
準備工做已經完成
咱們先寫一個方法,添加數據庫依賴
void AddSqlDependency(string strCon, string strSql, OnChangeEventHandler sqlDep_OnChange)
{
try
{
using (SqlConnection conn = new SqlConnection(strCon))
{
SqlCommand comm = new SqlCommand(strSql, conn);
SqlDependency sqlDep = new SqlDependency(comm);
sqlDep.OnChange += sqlDep_OnChange;
if (conn.State == ConnectionState.Closed) conn.Open();
comm.ExecuteNonQuery();
}
}
catch (Exception ex)
{
LogUtility.Add(ex);
}
}
//上面這個方法是告訴數據庫,當你指定表數據改變,要移出緩存
咱們如今能夠來添加了
MyObject obj= HttpRuntime.Cache["cacheName"] as MyObject;
if (null == obj)
{
try
{
obj= GetObj(...);
}
catch (Exception ex)
{
LogUtility.Add(ex);
obj= null;
}
if (null != obj)
{
AddSqlDependency(strCon, "select id from dbo.tableName;select id1 from dbo.tableName1",
delegate(object sender, SqlNotificationEventArgs e)
{
//do something
HttpRuntime.Cache.Remove("cacheName");
});
HttpRuntime.Cache.Insert("cacheName", obj);
}
}
上面SQL語句中用到的表,只要這些表中的任何數據有改動,數據庫都會通知,這時緩存會移動,select的字段和Cache沒有關係,只有表名有關係,全部你要選擇最小的字段.不少時候,爲了這個字段,在設計表的時候都爲多加一個最小的依賴列.
NOTE:任何Cache均可能丟失,使用前必定要作必要的檢查,如:
MyObject obj=HttpContext.Current.Cache("CacheName") as MyObject;
if(null==obj)
{
obj=.......
HttpContext.Current.Cache.Insert("CacheName",obj);
}
Cache用法之頁面聲明
<%@ outputCache
Duration="#ofseconds"
Location="Any|Client|Downstream|Server|None"
VaryByControl="ControlName"
VaryByCustom="browser|customstring"
VaryByHeader="headers"
VaryByParam="Parametername" %>
Cache用法之代碼控制
HttpCachePolicy類是專門用來控件Cache的,能夠用Response.Cahce來訪問這個類的實例
Response.Cache.SetExpires(DateTime.Now.AddSeceonds(10));
Response.Cache.SetCacheability(HttpCacheablility.Public);
Response.Cache.SetValidUnitlExpires(true);
-----------------------以上都是緩存頁面的,下面是緩存數據的----------------------------
Cache 類的生存週期等於應用程序的生命週期
三種用法
1:存:Cache["key"] = MyData;取:
MyData = Cache["key"];
if(MyData != null)
use(MyData);
此法存入Cache的數據生命週期等於應用程序生命週期,不支持清除、過時、依賴性等功能。
2:存:
Cache.Insert(
string key,
object value,
CacheDependency dependencies,//依賴,設置緩存有效的依賴性,好比設置和一個文件相關,文件一變,就失效
DateTime absoluteExpireation, //設置固定的過時時間
TimeSpan slidingExpiration, //設置最後一次訪問後多長時間過時
CachePriority priority, //設置內存不足,緩存自動清除時,緩存的重要性,可不能夠清除
CacheItemRemovedCallback onRemoveCallback // 設置在清除時引起的事件
)
Example:
Cache.Insert("Mydata",MyData,new Caching.CacheDependency(Server.MapPah("Mydata.XML")));//設置有效性和一個文件有關
Cache.Insert("Mydata",myData,null,DateTime.Now.AddDays(1),Cache.NoSlidingExpiratin);//兩種過時時間設了其中一種,另外一種要設爲0,用NoAbsolute(Sliding)Expiration枚舉
Cache.Insert("MyData",myData,null,Cache.NoAbsoluteExpiration,TimeSpan.FromMinutes(10));//不能過一年不能小於0
Cache.Insert("MyData",myData,null,Cache.NoAbsoluteExpiration,TimeSpan.FromMinutes(10),
Caching.CacheItemPriority.NotRemovable,null);
// AboveNormal|BelowNormal|Default|High|Low|Normal|NotRemovable
public void RemovedCallback(string key,object value,CacheItemRemovedReason reason)
{
if(reason == CacheItemRemovedReason.DependencyChanged)
Response.Write("文件變了,快去看看");
}
Cache.Insert("Mydata",MyData,new Caching.CacheDependency(Server.MapPah("Mydata.XML"),
DateTime.Now.AddDays(1),Cache.NoSlidingExpiration,CacheItemPriority.High,
new CacheItemRemovedCallback(this.RemovedCallback));
清除就能夠用Cache.Remove("key");方法
3:
Cache.Add方法,用法和Insert差很少,區別在於Add碰到該key原來有賦過值會失敗,Insert則不會,而會替換原有值;Add會返回被緩存數據項,Insert不會 sql