加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何将数据库数据缓存到内存以供MVC应用程序使用?

发布时间:2020-12-15 05:38:55 所属栏目:百科 来源:网络整理
导读:我有一个有点复杂的权限系统,总共使用六个数据库表,为了加快它,我想将这些表缓存在内存中,而不是每次页面加载时都要访问数据库. 但是,我需要在添加新用户或更改权限时更新此缓存.我不确定如何在内存缓存中使用它,以及如何安全地更新它而不会在更新的同时访问
我有一个有点复杂的权限系统,总共使用六个数据库表,为了加快它,我想将这些表缓存在内存中,而不是每次页面加载时都要访问数据库.

但是,我需要在添加新用户或更改权限时更新此缓存.我不确定如何在内存缓存中使用它,以及如何安全地更新它而不会在更新的同时访问它而不会引起问题

有没有人有一个如何做这样的事情的例子,或者能指出我正确的研究方向?

解决方法

在不了解应用程序结构的情况下,有很多可能的选择.其中一个选项可能是抽象存储库接口后面的数据访问,并处理该存储库中的内存缓存.像私人IEnumerable< T>这样简单的东西在存储库对象上.

因此,例如,假设您有一个User对象,其中包含有关用户的信息(名称,权限等).你有一个UserRepository,上面有一些基本的fetch / save方法.在该存储库中,您可以维护私有静态HashSet< User>它包含已从数据库中检索的User对象.

当您从存储库中获取用户时,它首先检查HashSet是否有要返回的对象,如果它没有找到它从数据库获取它,则将其添加到HashSet,然后返回它.保存用户时,它会同时更新HashSet和数据库.

同样,在不知道代码库和整体设计的细节的情况下,很难给出更具体的答案.但这应该是一个通用的解决方案,适用于任何应用程序.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读