Python语言技术文档

微信小程序技术文档

php语言技术文档

jsp语言技术文档

asp语言技术文档

C#/.NET语言技术文档

html5/css技术文档

javascript

点击排行

您现在的位置:首页 > 技术文档 > C#/.NET技巧

开启SQLSERVER数据库缓存依赖优化网站性能

来源:中文源码网    浏览:416 次    日期:2024-05-03 03:31:28
【下载文档:  开启SQLSERVER数据库缓存依赖优化网站性能.txt 】


开启SQLSERVER数据库缓存依赖优化网站性能
很多时候,我们服务器的性能瓶颈会是在查询数据库的时候,所以对数据库的缓存非常重要,那么有没有一种方法,可以实现SQL SERVER数据库的缓存,当数据表没有更新时,就从缓存中读取,当有更新的时候,才从数据表中读取呢,答案是肯定的,这样的话我们对一些常用的基础数据表就可以缓存起来,比如做新闻系统的新闻类别等,每次就不需要从数据库中读取了,加快网站的访问速度。 那么如何开启SQLSERVER数据库缓存依赖,方法如下: 第一步:修改Web.Config的节的配置,代码如下,让网站项目启用SqlCacheDependency。注意下面代码中的connectionStringName,就是指定的节中的数据库连接字符串变量名称。name则是为该SqlCacheDependency起的名字,这个名字将在第三步中用到。SqlCacheDependency类会自动完成对此配置节信息的读取以建立和数据库之间的联系。 复制代码 代码如下: 以下设置数据库缓存依赖方式--> 第二步:在CMD中执行下述命令,以开启SQL SERVER数据库对SqlCacheDependency的支持,利用aspnet_regsql.exe工具,该工具位于windows\microsoft.net\framework\[版本]文件夹中 代码如下: 复制代码 代码如下: aspnet_regsql -C "data source=127.0.0.1;initial catalog=YD_JWC_JAKE;user id=sa;password=" -ed -et -t "T_NewsClass" 参数-C后面跟着的是数据库连接字符串,注意字母C是大写。参数-t后面跟着的就是你要开启数据库缓存的数据表,此处我为新闻类别的表开启了缓存依赖。(如果有多个表,则重复执行此命令,注意修改你的数据表名) 第三步:在获取数据的业务层代码中,如果是第一次读取,则从数据库中读取后,存入缓存里。以后获取数据时,数据库会自动判断表是否有更新数据,如果有,则读数据库同时更新缓存,如果没有更新,则从数据库中读取。代码如下: 复制代码 代码如下: private void getInfoClass( int t) { string CacheKey = "cacheclass" + t.ToString(); object objModle = Jake.DataCache.GetCache(CacheKey);//从缓存中获取 DataTable dt=null; if (objModle == null)//如果缓存中没有则读取数据库 { Jake.BLL.NewsManage.NewsClass nc = new Jake.BLL.NewsManage.NewsClass(); dt = nc.GetList("").Tables[0]; objModle = dt; if (objModle != null) { System.Web.Caching.SqlCacheDependency dep = new System.Web.Caching.SqlCacheDependency("YD_JWC_JAKE", "T_NewsClass"); Jake.DataCache.SetCache(CacheKey, objModle, dep); } } else { dt = (DataTable)objModle; //缓存中有就直接读取缓存,不需要访问数据库 } DataRow[] drs = dt.Select("","classid"); StringBuilder sb =new StringBuilder(); sb.Append("
    "); foreach (DataRow r in drs) { string cid=r["ClassId"].ToString(); Security js = new Security(); string decrystr = Jake.Common.ConfigHelper.GetConfigString("DecryStr");//获得加密密钥 cid = js.EncryptQueryString(cid, decrystr); string cdesc=r["ClassDesc"].ToString(); if (t == 1) { sb.Append("
  • " + cdesc + "
  • "); } else if (t == 2) { sb.Append("
  • " + cdesc + "
  • "); } else sb.Append("
  • " + cdesc + "
  • "); } sb.Append("
"); Response.Write(sb); } 以上代码中Jake.DataCache.GetCache()方法是自己定义的一个获取和设置缓存的通用方法,单独编译成了DLL: 代码如下: 复制代码 代码如下: using System; using System.Collections.Generic; using System.Web; using System.Text; namespace Jake { public class DataCache { /// /// 获取当前应用程序指定CacheKey的Cache值 /// /// /// public static object GetCache(string CacheKey) { System.Web.Caching.Cache objCache = HttpRuntime.Cache; return objCache[CacheKey]; } /// /// 设置当前应用程序指定CacheKey的Cache值 /// /// /// public static void SetCache(string CacheKey, object objObject) { System.Web.Caching.Cache objCache = HttpRuntime.Cache; objCache.Insert(CacheKey, objObject); } /// /// 设置已缓存依赖的方式缓存数据 /// /// 键值 /// 缓存对象 /// 缓存依赖项 public static void SetCache(string CacheKey, object objObject, System.Web.Caching.CacheDependency dep) { System.Web.Caching.Cache objCache = HttpRuntime.Cache; objCache.Insert( CacheKey, objObject, dep, System.Web.Caching.Cache.NoAbsoluteExpiration,//从不过期 System.Web.Caching.Cache.NoSlidingExpiration,//禁用可调过期 System.Web.Caching.CacheItemPriority.Default, null ); } } } 至此,对于数据表的缓存依赖就已经开启,这样可以大大加快网站访问的速度。 (转载请注明本文出处:http://blog.csdn.net/j_jake)

相关内容