梦回侏罗纪 2017-09-22 07:05 采纳率: 100%
浏览 2966
已采纳

数据库表中所有记录放入java map后内存溢出

目前面临的问题:
与数据库频繁交互(select *from table where rowid=?),为防止过于频繁的访问数据库,在第一次操作时,将所有记录查询出来放入内存(java Map),之后每次操作从map中获取,
但同时引出了另一个问题,不能保证数据库里有多少数据,如果记录过多,会导致内存溢出。
恳请大神们指点迷津~!

  • 写回答

7条回答 默认 最新

  • _Yasin 博客专家认证 2017-09-23 02:06
    关注

    1.首选楼主想到了缓存的方式来解决数据库频繁读取问题的方向是对的,直接存储放到jvm的内存中肯定是不合适的,数据量大后会造成内存溢出。
    2.如何解决:使用redis缓存,将id作为key存放,不知道你具体的业务,如果业务中查询的id有重复,可以使用redis缓存,如果你业务中会查询id几乎不重复,
    那么查库是避免不了的。所以你可以在程序启动阶段,就把数据库中的数据分页查询插入到redis中,分页查询不会造成内存溢出,以后所有的查询都走redis,
    如果redis查不到,在去数据库查,并且将查询结果放入redis中。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

  • ¥15 evo评估时曲线出现问题
  • ¥15 eNSP拓扑图配置实验
  • ¥20 有没有兄弟会替换fmod studio的.bank文件内的音效?
  • ¥20 如何解决访问网址被屏蔽的情况
  • ¥15 本地运行的vue2项目,使用内网穿透,前端界面一直转圈圈
  • ¥20 powerbuilder datawindow控件导出Excel数据,可不可以不自动覆盖原数据,而是在后面新插入入数据。
  • ¥100 无轴承永磁同步电机控制
  • ¥15 eps里添加本地倾斜模型
  • ¥15 telegram 问题
  • ¥15 nrf52810-c三个a 程序