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

数据库表中所有记录放入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 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵