当前位置:  编程技术>.net/c#/asp.net

C#缓存之SqlCacheDependency用法实例总结

    来源: 互联网  发布时间:2014-11-01

    本文导语:  本文整理汇总了C#缓存的数据库依赖类SqlCacheDependency的使用方法,具体内容如下: 1、数据库依赖类SqlCacheDependency 数据库缓存依赖主要解决的是当数据库的内容发生改变时,如何及时通知缓存,并更新缓存中的数据的问题。 语...

本文整理汇总了C#缓存的数据库依赖类SqlCacheDependency的使用方法,具体内容如下:

1、数据库依赖类SqlCacheDependency

数据库缓存依赖主要解决的是当数据库的内容发生改变时,如何及时通知缓存,并更新缓存中的数据的问题。

语法定义:

SqlCacheDependency类主要的构造函数如下:

public SqlCacheDependency(string database,string table)

其中参数一代表要启用缓存的数据库,参数二表示缓存的表。在实际使用过程中,只需要指明缓存的数据库和表即可。

方法是属性的应用(代码与CacheDependency类似),不过Sql需要先进行一下对web.config进行配置和设置数据库的缓存配置一下才可以使用SqlCacheDependency缓存类

首先web.config配置如下:


 

 
  
 
 


 




 





2、Vs缓存配置:

 打开“开始”|“所有程序”|“Microsoft Visual Studio 2010”|“Visual Studio Tools”|“Visual Studio 2010命名提示”菜单命令。

 在命令框内输入:aspnet_regsql.exe -S  SqlServer服务器  -U -P -ed -d 数据库名称 -et -t 表名

  若无身份验证输入:aspnet_regsql.exe -S  SqlServer服务器  -ed -d 数据库名称 -et -t 表名

 执行命令即可;

3、页面代码;

private static SqlCacheDependency MyDep;
    protected void Page_Load(object sender, EventArgs e)
    {
      Label1.Text = DateTime.Now.ToString();
      if (!IsPostBack)
      {
        //Cache为数据库名,T_SqlCache为缓存表
        
        DataSet ds = GetSet();
        if (Cache["SqlCon"] == null)
        {
          //添加缓存SqlCon,缓存值为数据库表内容,
          MyDep = new SqlCacheDependency("Cache", "T_SqlCache");
          Cache.Add("SqlCon", ds, MyDep, DateTime.Now.AddSeconds(60), TimeSpan.Zero, CacheItemPriority.Normal, null);
        } 
        
      }
    }
     
    protected void Button1_Click(object sender, EventArgs e)
    {
      if (MyDep.HasChanged)
      {//当数据库值更改时提醒;
        Response.Write("数据库修改时间为:"+MyDep.UtcLastModified);
      }
      if (Cache["SqlCon"] == null)
      {//当缓存过期或数据库值修改后缓存从新加载
        MyDep = new SqlCacheDependency("Ajax", "T_AjaxLD");
        DataSet ds = GetSet();
        Cache.Add("SqlCon", ds, MyDep, DateTime.Now.AddSeconds(60), TimeSpan.Zero, CacheItemPriority.Normal, null);
      }
      this.GridView1.DataSource = Cache["SqlCon"];//绑定数据
      this.GridView1.DataBind();
    }
    /// 
    /// 生成Dataset
    /// 
    /// 
    private DataSet GetSet()
    {
      DataSet ds = new DataSet();
      string sql = "select * from T_SqlCache";
      string Config = ConfigurationManager.ConnectionStrings["Config"].ConnectionString;//连接数据库语句
      using (SqlConnection cnn = new SqlConnection(Config))
      {
        using (SqlCommand cmm = new SqlCommand(sql, cnn))
        {
          SqlDataAdapter dapter = new SqlDataAdapter(cmm);
          dapter.Fill(ds);
        }
      }
 
      return ds;
    }

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目前只能保存在内存中,对其性能有影响。

此外,需要特别注意:为了提高Cache的有效利用率,建议对于不经常改动的数据使用Cache。


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql的SQL_NO_CACHE(在查询时不使用缓存)和sql_cache用法
  • php输出缓存ob系列函数用法
  • Linux/Centos/Ubuntu清除系统缓存释放内存命令介绍
  • 磁盘缓存专题之一 缓存命中和缓存未命中&缓存与缓冲间的差异
  • andriod中ListView, listItem布局和convertView的缓存与重用详解
  • ubuntu下类似windows的缓存文件,上网缓存文件在哪里阿?
  • CodeIgniter启用缓存和清除缓存的方法
  • 有关asp.net中Session缓存与Cache缓存的区别
  • php页面缓存的例子 php缓存降低mysql压力
  • 使用Memcache缓存mysql数据库操作的原理和缓存过程浅析
  • 请大家帮助,我用red hat as 5做代理服务器,客户端机器上网时常会出现缓存不足的情况,我把缓存加大后仍然无效,请问大家如何解决此问题?谢谢你们!
  • JSP动态缓存 JimStoneCache
  • java缓存工具 SimpleCache
  • 简单的php缓存类分享 php缓存机制
  • android开发教程之清除android数据缓存示例(清除本地数据缓存)
  • 一个页高速缓存的问题
  • Java缓存框架 Ehcache
  • mysql 设置查询缓存
  • 页面高速缓存 块缓冲区 TLB
  • Java 缓存系统 JBossCache
  • Android 缓存框架 ASimpleCache
  • ThinkPHP缓存方法S()概述
  • Linux/Centos/Ubuntu清除系统缓存释放内存命令介绍 iis7站长之家


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3