12

我正在使用休眠+播放!框架在工作,是否有使用休眠插入大量记录的“最佳实践”?每个文本文件大约有 6,000 到 10,000 个,所以我不知道 Hibernate 是否会阻塞工作或引发异常。

任何建议让我知道,如果我需要解释更多,请告诉我

4

5 回答 5

24

来自 *Java Persistence and Hibernate" (Manning) 并遵循 Pangea 的评论,使用无状态会话(没有持久性上下文缓存):

StatelessSession session = sessionFactory.openStatelessSession();
Transaction tx = session.beginTransaction();
for ( int i=0; i<100000; i++ ) {
    Item item = new Item(...);
    session.insert(item);
}
tx.commit();
session.close();
于 2011-01-03T19:46:17.190 回答
3

只是对 Kartoch 答案中的代码进行了一些更正。

根据Batch Procession,“StatelessSession 接口定义的 insert()、update() 和 delete() 操作被认为是直接的数据库行级操作。它们分别导致立即执行 SQL INSERT、UPDATE 或 DELETE . 它们对 Session 接口定义的 save()、saveOrUpdate() 和 delete() 操作有不同的语义。”

StatelessSession 不再需要 save()、flush()、clear()。代码应该是这样的:

StatelessSession session = sessionFactory.openStatelessSession();
Transaction tx = session.beginTransaction();

for ( int i=0; i<100000; i++ ) {
  Item item = new Item(.....);
  session.insert(item );
}    

tx.commit();
session.close();

最后,这里讨论一下普通批量插入和StatelessSession插入的区别:Using StatelessSession for Batch processing

于 2015-01-08T16:03:17.643 回答
2

最好是使用无状态会话。考虑以下来自(http://docs.jboss.org/hibernate/orm/3.3/reference/en-US/html/batch.html)的示例:

StatelessSession session = sessionFactory.openStatelessSession();
Transaction tx = session.beginTransaction();

ScrollableResults customers = session.getNamedQuery("GetCustomers")
    .scroll(ScrollMode.FORWARD_ONLY);
while ( customers.next() ) {
    Customer customer = (Customer) customers.get(0);
    customer.updateStuff(...);
    session.update(customer);
}

tx.commit();
session.close();
于 2013-08-06T03:24:08.030 回答
1

只需打开您的会话和交易。

在会话的保存中添加所有元素。

然后提交事务。

//Remember to effective handler errors
public void saveAll(List<Object> list) throws Exception{
Session s = HibernateUtil.openSession();
Transaction tx = s.beginTransaction();
for(Object obj : list)
 s.save(obj);
tx.commit();
s.flush();
s.close();
}
于 2011-01-03T19:35:21.553 回答
-5

如果您想在休眠之外进行插入,则始终可以直接获取 Connection 对象。

Connection connection = DB.getConnection();
于 2011-01-03T20:31:05.230 回答