• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

asp 搞代码 4年前 (2022-01-03) 35次浏览 已收录 0个评论

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

很多时候,我们服务器的性能瓶颈会是在查询数据库的时候,所以对数据库的缓存非常重要,那么有没有一种方法,可以实现SQL SERVER数据库的缓存,当数据表没有更新时,就从缓存中读取,当有更新的时候,才从数据表中读取呢,答案是肯定的,这样的话我们对一些常用的基础数据表就可以缓存起来,比如做新闻系统的新闻类别等,每次就不需要从数据库中读取了,加快网站的访问速度。
那么如何开启SQLSERVER数据库缓存依赖,方法如下:
第一步:修改Web.Config的节的配置,代码如下,让网站项目启用SqlCacheDependency。注意下面代码中的connectionStringName,就是指定的节中的数据库连接字符串变量名称。name则是为该SqlCacheDependency起的名字,这个名字将在第三步中用到。SqlCacheDependency类会自动完成对此配置节信息的读取以建立和

来源gao!daima.com搞$代!码网

数据库之间的联系。

代码如下:

type=”URLRewriter.RewriterFactoryHandler, URLRewriter” />
type=”URLRewriter.RewriterFactoryHandler, URLRewriter” />
type=”URLRewriter.RewriterFactoryHandler, URLRewriter” />

<!–
设置 compilation debug=”true” 将调试符号插入
已编译的页面中。但由于这会
影响性能,因此只在开发过程中将此值
设置为 true。
–>

<!–
通过 节可以配置 ASP.NET 使用的
安全身份验证模式,
以标识传入的用户。
–>

<!–
如果在执行请求的过程中出现未处理的错误,
则通过 节可以配置相应的处理步骤。具体说来,
开发人员通过该节可以配置
要显示的 html 错误页
以代替错误堆栈跟踪。–>

第二步:在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.gaodaima.com/j_jake)

以上就是开启SQLSERVER数据库缓存依赖优化网站性能的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:开启SQLSERVER数据库缓存依赖优化网站性能

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址