数据库组件 Hxj.Data (二十三) (自定义缓存)
配置的缓存并不能满足我们的需求,例如有时候需要刷新缓存,或者某次查询缓存时间或者缓存依赖 不一样等。 刷新缓存 例如: DbSession.Default.From<Products>().Where(Products._.ProductID == 1).Refresh ().ToFirst(); Refresh()方法设置了刷新缓存,即不从缓存中读取,直接从数据库读取最新数据,并重新缓存。 设置查询的缓存有效期。 例如: DbSession.Default.From<Products>().Where(Products._.ProductID == 1).SetCacheTimeOut(180).ToFirst(); 设置该查询的缓存时间为180秒。 该设置会覆盖默认缓存配置,并且缓存配置中没有实体设置,也会缓存。 当下次执行: DbSession.Default.From<Products>().Where(Products._.ProductID == 1).ToFirst(); 在180秒内缓存有效。 设置缓存依赖。 例如: System.Web.Caching.CacheDependency cacheDep = new System.Web.Caching.CacheDependency (Server.MapPath("~/2.txt")); DbSession.Default.From<Products>().Where(Products._.ProductID == 1).SetCacheDependency(cacheDep).ToFirst(); 设置该查询缓存的缓存依赖为2.txt文件。 该设置会覆盖默认缓存配置,并且缓存配置中没有实体设置,也会缓存。 当再次执行: DbSession.Default.From<Products>().Where(Products._.ProductID == 1).ToFirst(); 如果2.txt文件没有改变,缓存是不会失效的。 当然这几个方法也可以同时使用。 缓存是根据生成的sql作为缓存依据的,所以写法确保一致,特别是条件的先后顺序,才能有效利用缓 存,否则就要浪费内存了。 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |