我想在我的 asp.net-mvc 站点中缓存最繁重的数据库操作。
在我的研究中我发现
-
甜甜圈缓存在菲尔的博客上
-
缓存/压缩Kazi 博客上的过滤器
- Scott Hansleman 的播客介绍了他们如何在 SO 中缓存内容。
但我觉得我还没明白。
我希望能够根据几个参数缓存我的 POST 请求。这些部分位于一个对象中。所以我想缓存以下请求的结果:
public ActionResult AdvancedSearch(SearchBag searchBag)
其中 searchBag 是一个包含(一堆)可选搜索参数的对象。
我的观点本身很简单(理应如此),但数据访问可能相当耗时,具体取决于搜索包中填写的字段。
我觉得我应该缓存在我的数据层上,而不是我的操作上。
我应该如何在 OutputCache 属性中使用 VaryByParam?
我也喜欢在模型或数据层中缓存。这隔离了与从控制器/演示文稿检索数据有关的所有内容。您可以从以下位置访问 ASP.NET 缓存:System.Web.HttpContext.Current.Cache
或使用企业库中的缓存应用程序块。根据查询参数为缓存数据创建密钥。更新数据时请务必使缓存失效。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)