<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        開啟SQLSERVER數據庫緩存依賴優化網站性能

        來源:懂視網 責編:小采 時間:2020-11-27 22:43:10
        文檔

        開啟SQLSERVER數據庫緩存依賴優化網站性能

        開啟SQLSERVER數據庫緩存依賴優化網站性能:很多時候,我們服務器的性能瓶頸會是在查詢數據庫的時候,所以對數據庫的緩存非常重要,那么有沒有一種方法,可以實現SQL SERVER數據庫的緩存,當數據表沒有更新時,就從緩存中讀取,當有更新的時候,才從數據表中讀取呢,答案是肯定的,這樣的話我們對一些常
        推薦度:
        導讀開啟SQLSERVER數據庫緩存依賴優化網站性能:很多時候,我們服務器的性能瓶頸會是在查詢數據庫的時候,所以對數據庫的緩存非常重要,那么有沒有一種方法,可以實現SQL SERVER數據庫的緩存,當數據表沒有更新時,就從緩存中讀取,當有更新的時候,才從數據表中讀取呢,答案是肯定的,這樣的話我們對一些常

        很多時候,我們服務器的性能瓶頸會是在查詢數據庫的時候,所以對數據庫的緩存非常重要,那么有沒有一種方法,可以實現SQL SERVER數據庫的緩存,當數據表沒有更新時,就從緩存中讀取,當有更新的時候,才從數據表中讀取呢,答案是肯定的,這樣的話我們對一些常用的基礎數據表就可以緩存起來,比如做新聞系統的新聞類別等,每次就不需要從數據庫中讀取了,加快網站的訪問速度。
        那么如何開啟SQLSERVER數據庫緩存依賴,方法如下:
        第一步:修改Web.Config的<system.web>節的配置,代碼如下,讓網站項目啟用SqlCacheDependency。注意下面代碼中的connectionStringName,就是指定的<connectionStrings>節中的數據庫連接字符串變量名稱。name則是為該SqlCacheDependency起的名字,這個名字將在第三步中用到。SqlCacheDependency類會自動完成對此配置節信息的讀取以建立和數據庫之間的聯系。
        代碼如下:

        <system.web>
        <httpHandlers>
        <add verb="*" path="*.aspx"
        type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
        <add verb="*" path="*.shtml"
        type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
        <add verb="*" path="*.bobo"
        type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
        </httpHandlers>
        <!-->以下設置數據庫緩存依賴方式-->
        <caching>
        <sqlCacheDependency enabled="true" pollTime="6000">
        <databases>
        <add name="YD_JWC_JAKE" connectionStringName="cachestr"/>
        </databases>
        </sqlCacheDependency>
        </caching>
        <!--
        設置 compilation debug="true" 將調試符號插入
        已編譯的頁面中。但由于這會
        影響性能,因此只在開發過程中將此值
        設置為 true。
        -->
        <compilation debug="true">
        <assemblies>
        <add assembly="System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=B03F5F7F11D50A3A"/>
        </assemblies>
        </compilation>
        <!--
        通過 <authentication> 節可以配置 ASP.NET 使用的
        安全身份驗證模式,
        以標識傳入的用戶。
        -->
        <authentication mode="Forms">
        <forms loginUrl="login.aspx" name=".AJSUPCXAIUTH"></forms>
        </authentication>
        <authorization>
        <allow users="*"/>
        </authorization>
        <!--
        如果在執行請求的過程中出現未處理的錯誤,
        則通過 <customErrors> 節可以配置相應的處理步驟。具體說來,
        開發人員通過該節可以配置
        要顯示的 html 錯誤頁
        以代替錯誤堆棧跟蹤。-->
        <customErrors mode="RemoteOnly" defaultRedirect="/ER3.shtml">
        <error statusCode="403" redirect="/ER1.shtml" />
        <error statusCode="404" redirect="/ER404.shtml" />
        </customErrors>
        </system.web>

        第二步:在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("<ul>");
        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("<li><a href="/Info" + cid + ".shtml" href="Info" + cid + ".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
        }
        else if (t == 2)
        {
        sb.Append("<li><a href="/File" + cid +".shtml" href="File" + cid +".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
        }
        else
        sb.Append("<li><a href="/FAQ" + cid + ".shtml" href="FAQ" + cid + ".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
        }
        sb.Append("</ul>");
        Response.Write(sb);
        }

        以上代碼中Jake.DataCache.GetCache()方法是自己定義的一個獲取和設置緩存的通用方法,單獨編譯成了DLL:
        代碼如下:
        代碼如下:

        using System;
        using System.Collections.Generic;
        using System.Web;
        using System.Text;
        namespace Jake
        {
        public class DataCache
        {
        /// <summary>
        /// 獲取當前應用程序指定CacheKey的Cache值
        /// </summary>
        /// <param name="CacheKey"></param>
        /// <returns></returns>
        public static object GetCache(string CacheKey)
        {
        System.Web.Caching.Cache objCache = HttpRuntime.Cache;
        return objCache[CacheKey];
        }
        /// <summary>
        /// 設置當前應用程序指定CacheKey的Cache值
        /// </summary>
        /// <param name="CacheKey"></param>
        /// <param name="objObject"></param>
        public static void SetCache(string CacheKey, object objObject)
        {
        System.Web.Caching.Cache objCache = HttpRuntime.Cache;
        objCache.Insert(CacheKey, objObject);
        }
        /// <summary>
        /// 設置已緩存依賴的方式緩存數據
        /// </summary>
        /// <param name="CacheKey">鍵值</param>
        /// <param name="objObject">緩存對象</param>
        /// <param name="dep">緩存依賴項</param>
        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)

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        開啟SQLSERVER數據庫緩存依賴優化網站性能

        開啟SQLSERVER數據庫緩存依賴優化網站性能:很多時候,我們服務器的性能瓶頸會是在查詢數據庫的時候,所以對數據庫的緩存非常重要,那么有沒有一種方法,可以實現SQL SERVER數據庫的緩存,當數據表沒有更新時,就從緩存中讀取,當有更新的時候,才從數據表中讀取呢,答案是肯定的,這樣的話我們對一些常
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲中文无韩国r级电影| 成年女人色毛片免费看| 亚洲一区二区三区自拍公司| 麻豆一区二区三区蜜桃免费| 国产精品免费一级在线观看| 日韩电影免费在线观看网址 | 免费看片在线观看| 中文字幕亚洲免费无线观看日本| 久久国产高潮流白浆免费观看| 亚洲AV日韩AV天堂一区二区三区| 免费国产在线视频| 噜噜噜亚洲色成人网站∨| 69av免费视频| 亚洲欧美第一成人网站7777| 又粗又硬又黄又爽的免费视频| av午夜福利一片免费看久久| 亚洲情综合五月天| 亚洲一区二区三区免费在线观看| 亚洲另类无码一区二区三区| 国产99视频精品免费视频7| 一级中文字幕免费乱码专区| 伊人久久综在合线亚洲91| 免费国产污网站在线观看15| 亚洲an日韩专区在线| 免费一级国产生活片| 巨胸喷奶水www永久免费| 亚洲精品中文字幕无码AV| 午夜免费福利影院| 国产一级在线免费观看| 911精品国产亚洲日本美国韩国| 操美女视频免费网站| 产传媒61国产免费| 久久亚洲AV成人出白浆无码国产| 在线观看免费毛片| 精品人妻系列无码人妻免费视频| 亚洲欧洲精品久久| 亚洲av高清在线观看一区二区| 国产午夜成人免费看片无遮挡| 亚洲最大的黄色网| 亚洲啪啪综合AV一区| 岛国片在线免费观看|