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

数据库表中所有记录放入java map后内存溢出
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
7条回答 默认 最新
关注
1.首选楼主想到了缓存的方式来解决数据库频繁读取问题的方向是对的,直接存储放到jvm的内存中肯定是不合适的,数据量大后会造成内存溢出。
2.如何解决:使用redis缓存,将id作为key存放,不知道你具体的业务,如果业务中查询的id有重复,可以使用redis缓存,如果你业务中会查询id几乎不重复,
那么查库是避免不了的。所以你可以在程序启动阶段,就把数据库中的数据分页查询插入到redis中,分页查询不会造成内存溢出,以后所有的查询都走redis,
如果redis查不到,在去数据库查,并且将查询结果放入redis中。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报