如何在asp.net mvc 4中缓存服务器上的数据?

viv*_*vek 22 c# sql-server asp.net caching asp.net-mvc-4

我正在研究mvc4 Web应用程序.我想在服务器端缓存一些数据库查询结果和视图.我用了-

HttpRuntime.Cache.Insert()
Run Code Online (Sandbox Code Playgroud)

但它在客户端缓存数据.请帮忙.

小智 41

我正在使用MemoryCache存储查询结果,到目前为止工作正常.
以下是我用来实现它的一些链接.
- 在.NET 4.0中使用MemoryCache(codeproject)
- 在.NET 4.0中使用MemoryCache(博客条目)

当我现在阅读它们时,我发现它们并不那么清楚,所以也许有一个更好的链接我已经丢失了.
这是我的代码示例,我希望它足够清晰,以便您了解它是如何工作的

public static class AgencyCacheManager
{
    private static MemoryCache _cache = MemoryCache.Default;

    public static List<RefAgency> ListAgency
    {
        get
        {
            if (!_cache.Contains("ListAgency"))
                RefreshListAgency();
            return _cache.Get("ListAgency") as List<Agency>;
        }
    }

    public static void RefreshListAgency()
    {
        var listAgency = GetAllComplete();

        CacheItemPolicy cacheItemPolicy = new CacheItemPolicy();
        cacheItemPolicy.AbsoluteExpiration = DateTime.Now.AddDays(1);

        _cache.Add("ListAgency", listAgency, cacheItemPolicy);
    }
}
Run Code Online (Sandbox Code Playgroud)

并从缓存中检索列表

public Agency FindBy(string agencyId)
{
    return AgencyCacheManager.ListAgency.SingleOrDefault(x => x.AgencyPartnerCode == agencyId);
}
Run Code Online (Sandbox Code Playgroud)