如何使用hibernate将多行插入数据库?
我正在循环列表并插入数据库,但它逐个更新记录。最后我只在数据库的最后一个记录中看到了这一点。
输入名称:Linux,windows,mac
Session session = (Session) HibernateUtil.getSessionFactory().openSession(); String[] items = pi.getNewLicenseName().split(","); for (String item : items) { feature.setName(item); session.save(feature); } session.getTransaction().commit(); HibernateUtil.shutdown();
hibernate.cfg.xml中:
com.microsoft.sqlserver.jdbc.SQLServerDriver jdbc:sqlserver://****** ***** ***** org.hibernate.dialect.SQLServerDialect org.hibernate.cache.internal.NoCacheProvider thread org.hibernate.context.internal.ThreadLocalSessionContext true update
这里三次得到循环并插入数据库。但以某种方式覆盖了值。因为我看到sql insert和update在控制台中运行。
Hibernate: insert into FEATURE (NAME) values (?) Hibernate: update FEATURE set NAME=? where FEATURE_ID=?
请帮我把多行插入数据库。
在Hibernate文档中有关于批处理的非常好的章节。
设置属性
hibernate.jdbc.batch_size 20
然后使用此代码
Session session = sessionFactory.openSession(); Transaction tx = session.beginTransaction(); for ( int i=0; i<100000; i++ ) { Customer customer = new Customer(.....); session.save(customer); if ( i % 20 == 0 ) { //20, same as the JDBC batch size //flush a batch of inserts and release memory: session.flush(); session.clear(); } } tx.commit(); session.close();
确保您考虑对您的id生成策略的影响,例如此处讨论 。
更新2015-09-23
我终于找到了坐下来写一篇详细文章的时间, url是http://frightanic.com/software-development/jpa-batch-inserts/ 。
使用会话中的save()
方法,Hibernate将对象耦合到一行,并且在会话保持活动状态时此关系保持不变。 因此,如果使用相同的对象,则实际更新现有行。 解决方案是为每一行构造一个新对象。 在这种情况下:
for (String item : items) { Feature feature = new Feature(); feature.setName(item); session.save(feature); }
session.merge(object); session.flush(); session.clear();
- Hibernate – ClassNotFoundException:com.mysql.jdbc.Driver
- 从数据库加载26MB文本数据消耗了258MB的JVM堆
- 多对多无效对象名称
- JPA Hibernate希望延迟加载返回空集合
- org.hibernate.PropertyValueException:not-null属性引用一对一关系中的null或transient值
- 使用Hibernate OGM进行MongoDb身份validation
- Hibernate – 忽略唯一列约束
- 如何根据用户的选择动态生成SQL查询?
- 使用@Transactional时,EntityManager.persist()不会插入数据