【发布时间】:2011-07-30 10:03:16
【问题描述】:
我需要解析一个非常大的文件并将生成的实体存储在数据库中。 我预计每个文件最多有 15 万条记录,并且可能会批量处理这些记录。
有没有办法用 JPA 批量插入 Play 实体?
【问题讨论】:
标签: java hibernate jpa playframework
我需要解析一个非常大的文件并将生成的实体存储在数据库中。 我预计每个文件最多有 15 万条记录,并且可能会批量处理这些记录。
有没有办法用 JPA 批量插入 Play 实体?
【问题讨论】:
标签: java hibernate jpa playframework
为了节省内存,您必须确保定期清除会话,所以
Customer.em().getTransaction().begin();
for ( int i=1; i<=100000; i++ ) {
....
myCustomer.save();
if (i%1000==0) {
//Customer.em().getTransaction().commit();
Customer.em().flush();
Customer.em().clear();
//Customer.em().getTransaction().begin();
}
}
Customer.em().getTransaction().commit();
如果您优化批量大小,您将如何提高性能
hibernate.jdbc.batch_size 100
您可以简单地将最后一行添加到application.conf,所有hibernate.* 属性直接进入hibernate。详情见JPAPlugin的代码。
【讨论】:
由于 Play 在后台使用 Hibernate,您应该能够使用 Hibernate 使用的标准批处理。见http://docs.jboss.org/hibernate/core/3.3/reference/en/html/batch.html
但是,Play 会自动为您管理事务,因此,如果您需要防止 Play 干扰事务管理,您可以使用 @play.db.jpa.NoTransaction 注释您的方法。
您可以在此处http://www.playframework.org/documentation/1.2.1/jpa 阅读有关 Play 的 JPA 和事务支持的更多信息
【讨论】: