zoukankan      html  css  js  c++  java
  • C# 缓存学习总结

    昨天整理了一下缓存的基本用法,和缓存依赖类 CacheDependency类的使用,今天整理一下缓存的数据库依赖类SqlCacheDependency

    1、数据库依赖类SqlCacheDependency

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

    语法定义:

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

    public SqlCacheDependency(string database,string table)

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

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

    第一步web.config配置如下:

     <!--连接数据库语句-->
    
    <configuration>
      <connectionStrings>
        <add name="Config" connectionString="Data Source=.;Initial Catalog=CacheData;Persist Security Info=True;User ID=sa;Password=123" providerName="System.Data.SqlClient"/>
      </connectionStrings>
    
    <!--在system.web节点下添加-->
    <!--注意事项:配置中add name值为数据库名,connectionStringName为连接数据库字段的名称要相同-->
    
    <caching>
          <sqlCacheDependency enabled="true" pollTime="1000">
    
            <databases>
              <add name="CacheData" connectionStringName="Config" pollTime="1000"/>
            </databases>
          </sqlCacheDependency>
          
        </caching>
    

     2、Vs缓存配置:

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

     在命令框内输入:aspnet_regsql.exe -S  SqlServer服务器  -U <Username> -P <Password> -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();
            }
            /// <summary>
            /// 生成Dataset
            /// </summary>
            /// <returns></returns>
            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。

      

  • 相关阅读:
    IG GROUP开源RESTdoclet项目
    Visual Studio 2012 Update 1抢先看
    使用 Windows Azure 移动服务将云添加到您的应用
    WMF 3.0 RTM(包含PowerShell 3.0 )业已发布
    Node.js 0.9.2 发布(非稳定版)
    vsftpd 3.0.1 正式版发布
    Piggydb 6.2 发布,个人知识库管理
    Apache Commons Codec 1.7 发布
    Notepad++ 6.1.8 正式版发布
    gWaei 3.6.0 发布,英日词典
  • 原文地址:https://www.cnblogs.com/xiao-bei/p/3899046.html
Copyright © 2011-2022 走看看