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

数据库表中所有记录放入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 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
  • ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序