加载Java实体时内存不足
我有一个可怕的问题,希望有一个非常简单的答案.当我执行基本操作时,我的内存不足 如果我有这样的代码:
而find()方法是一个标准的EntityManager相关方法:
这段代码工作了几周,如果数据库中的项目较少,则可以正常工作.我面临的结果是: java.lang.OutOfMemoryError:超出了GC开销限制 异常来自oracle toplink调用一些oracle jdbc方法. 循环存在是因为EJBQL(例如“将MyEntity中的选择对象(o)作为o”)会在有大量记录时使应用程序服务器过载. 最佳答案
这里没什么好奇怪的.由em.find()加载的实体被放置并保存在持久化上下文(在内存中)以跟踪更改,因此如果您在没有预防措施的情况下批量加载过多的实体,那么您将只是爆炸内存并获得OOME. 如果您确实需要对所有实体执行某些操作,则需要先调用flush()将所有更改推送到数据库,然后清除()以清除持久上下文并定期释放内存:
调用clear()会导致所有托管实体分离.对未刷新到数据库的实体所做的更改将不会保留.因此需要首先刷新()更改. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |