我们公司产品要升级,要求新版本兼容老版本, 我做数据库这块,数据库是oracle10g,以前存储的数据类型都是sys.xml格式的 xml文件,现在要求在新版本上用JPA操作数据库,所有要办所有的xml 通过jaxb2 转换成 Ojbect ,这些都没有问题,但是考虑到用户客户以前有海量的数据,他们要把老数据导入到新数据库中,我的做法是先把各个表中所有的 xml查询出来,分别转化成object,然后用List存储,然而这就遇到了内存(堆)溢出问题,如何解决这个问题,或者有没有更好的 解决方案,期待您的答案!!

解决方案 »

  1.   

    先尝试一下补充一下内存试试看,如果你用eclipse开发的话可以在窗口首选项中配置,具体原理如下:其默认空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1 /4。如果内存剩余不到40%,JVM就会增大堆到Xmx设置的值,内存剩余超过70%,JVM就会减小堆到Xms设置的值。所以服务器的Xmx和Xms 设置一般应该设置相同避免每次GC后都要调整虚拟机堆的大小。假设物理内存无限大,那么JVM内存的最大值跟操作系统有关,一般32位机是1.5g到3g 之间,而64位的就不会有限制了。