C#缓存之SqlCacheDependency用法实例总结
本文整理汇总了C#缓存的数据库依赖类SqlCacheDependency的使用方法,具体内容如下:
1、数据库依赖类SqlCacheDependency
数据库缓存依赖主要解决的是当数据库的内容发生改变时,如何及时通知缓存,并更新缓存中的数据的问题。
语法定义:
SqlCacheDependency类主要的构造函数如下:
publicSqlCacheDependency(stringdatabase,stringtable)
其中参数一代表要启用缓存的数据库,参数二表示缓存的表。在实际使用过程中,只需要指明缓存的数据库和表即可。
方法是属性的应用(代码与CacheDependency类似),不过Sql需要先进行一下对web.config进行配置和设置数据库的缓存配置一下才可以使用SqlCacheDependency缓存类
首先web.config配置如下:
<!--连接数据库语句--> <configuration> <connectionStrings> <addname="Config"connectionString="DataSource=.;InitialCatalog=CacheData;PersistSecurityInfo=True;UserID=sa;Password=123"providerName="System.Data.SqlClient"/> </connectionStrings> <!--在system.web节点下添加--> <!--注意事项:配置中addname值为数据库名,connectionStringName为连接数据库字段的名称要相同--> <caching> <sqlCacheDependencyenabled="true"pollTime="1000"> <databases> <addname="CacheData"connectionStringName="Config"pollTime="1000"/> </databases> </sqlCacheDependency> </caching>
2、Vs缓存配置:
打开“开始”|“所有程序”|“MicrosoftVisualStudio2010”|“VisualStudioTools”|“VisualStudio2010命名提示”菜单命令。
在命令框内输入:aspnet_regsql.exe-S SqlServer服务器 -U<Username>-P<Password>-ed-d数据库名称-et-t表名
若无身份验证输入:aspnet_regsql.exe-S SqlServer服务器 -ed-d数据库名称-et-t表名
执行命令即可;
3、页面代码;
privatestaticSqlCacheDependencyMyDep; protectedvoidPage_Load(objectsender,EventArgse) { Label1.Text=DateTime.Now.ToString(); if(!IsPostBack) { //Cache为数据库名,T_SqlCache为缓存表 DataSetds=GetSet(); if(Cache["SqlCon"]==null) { //添加缓存SqlCon,缓存值为数据库表内容, MyDep=newSqlCacheDependency("Cache","T_SqlCache"); Cache.Add("SqlCon",ds,MyDep,DateTime.Now.AddSeconds(60),TimeSpan.Zero,CacheItemPriority.Normal,null); } } } protectedvoidButton1_Click(objectsender,EventArgse) { if(MyDep.HasChanged) {//当数据库值更改时提醒; Response.Write("数据库修改时间为:"+MyDep.UtcLastModified); } if(Cache["SqlCon"]==null) {//当缓存过期或数据库值修改后缓存从新加载 MyDep=newSqlCacheDependency("Ajax","T_AjaxLD"); DataSetds=GetSet(); Cache.Add("SqlCon",ds,MyDep,DateTime.Now.AddSeconds(60),TimeSpan.Zero,CacheItemPriority.Normal,null); } this.GridView1.DataSource=Cache["SqlCon"];//绑定数据 this.GridView1.DataBind(); } ///<summary> ///生成Dataset ///</summary> ///<returns></returns> privateDataSetGetSet() { DataSetds=newDataSet(); stringsql="select*fromT_SqlCache"; stringConfig=ConfigurationManager.ConnectionStrings["Config"].ConnectionString;//连接数据库语句 using(SqlConnectioncnn=newSqlConnection(Config)) { using(SqlCommandcmm=newSqlCommand(sql,cnn)) { SqlDataAdapterdapter=newSqlDataAdapter(cmm); dapter.Fill(ds); } } returnds; }
C#缓存基本内容就差不多这些,一些应用需要在实践中总结出来,此处顺便分析一下session和Cache的区别:
Session和Cache的区别:
以前实现数据的缓存有很多种方法,有客户端的Cookie,有服务器端的Session和Application。其中Cookie是保存在客户端的一组数据,主要用来保存用户名等个人信息。Session则保存对话信息。Application则是保存在整个应用程序范围内的信息,相当于全局变量。通常使用最频繁的是Session,那么Session和Cache又有什么区别呢?
本节结合使用经验,详细介绍Session缓存和Cache缓存的区别如下:
(1)最大的区别是Cache提供缓存依赖来更新数据,而Session只能依靠定义的缓存时间来判断缓存数据是否有效。
(2)即使应用程序终止,只要Cache.Add方法中定义的缓存时间未过期,下次开启应用程序时,缓存的数据依然存在。而Session缓存只是存在于一次会话中,会话结束后,数据也就失效了。
(3)Session容易丢失,导致数据的不确定性,而Cache不会出现这种情况。
(4)由于Session是每次会话就被加载,所以不适宜存放大量信息,否则会导致服务器的性能降低。而Cache则主要用来保存大容量信息,如数据库中的多个表。
(5)VS2005的测试版提供了将缓存保存在硬盘上的参数,但正式版中取消了这个功能,估计其在以后版本中会重新实现。而Session目前只能保存在内存中,对其性能有影响。
此外,需要特别注意:
相关文章
- c#byte数组转换成字符串_字符串数组怎么定义
- 【地铁上的Redis与C#】Redis 简介
- C# 中检查null的语法糖,非常实用
- 【愚公系列】2023年02月 .NET/C#知识点-.NET Core配置文件详解
- c#可变数目参数params实例
- C#生成随机字符串的实例
- c#典型工厂化实现实例
- 浅谈C#中Process类的使用详解
- 浅谈C#2.0泛型中的变化:default关键字
- c#基础学习之多态
- c#dataTable合并两个列到一个新列中的简单实例
- c#模拟jsescape方法的简单实例
- C#使用MailAddress类发送html格式邮件的实例代码
- C#memcached缓存使用实例代码
- c#检测端口是否被占用的简单实例
- c#构造ColorComboBox(颜色下拉框)
- C#实现json的序列化和反序列化实例代码
- c#唯一值渲染实例代码
- c#获取光标在屏幕中位置的简单实例
- c#制作类似qq安装程序一样的单文件程序安装包
- c#处理3种json数据的实例
- C#控制台程序实现开启、关闭SQLServer服务的代码分享
- C#Memcached缓存用法实例详解
- C#Page用于各页面继承功能实例
- C#中读取App.config配置文件代码实例
- C#统计字符串里中文汉字个数的方法
- 基于C#实现的三层架构实例
- C#中使用UDP通信实例
- C#处理文本文件TXT实例详解
- C#获取Word文档中所有表格的实现代码分享
- C#实现对图片文件的压缩、裁剪操作实例