我正在循环列表并插入数据库,但它逐个更新记录.最后我只在数据库的最后一个记录中看到了这个.
输入名称: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();
Run Code Online (Sandbox Code Playgroud)
hibernate.cfg.xml中:
<hibernate-configuration>
<session-factory>
<property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
<property name="connection.url">jdbc:sqlserver://******</property>
<property name="connection.username">*****</property>
<property name="connection.password">*****</property>
<property name="dialect">org.hibernate.dialect.SQLServerDialect</property>
<property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>
<property name="hibernate.current_session_context_class">thread</property>
<property name="hibernate.current_session_context_class">org.hibernate.context.internal.ThreadLocalSessionContext</property>
<property name="show_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- Names the annotated entity class -->
<mapping class="com.DAO.Feature"/>
</session-factory>
Run Code Online (Sandbox Code Playgroud)
这里三次得到循环并插入数据库.但以某种方式覆盖了值.因为我看到sql insert和update在控制台中运行.
Hibernate: insert into FEATURE (NAME) values (?)
Hibernate: update FEATURE set NAME=? where FEATURE_ID=?
Run Code Online (Sandbox Code Playgroud)
请帮我把多行插入数据库.
Mar*_*tör 30
关于Hibernate文档中的批处理有一个非常好的章节.
设置属性
hibernate.jdbc.batch_size 20
Run Code Online (Sandbox Code Playgroud)
然后使用此代码
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();
Run Code Online (Sandbox Code Playgroud)
确保您考虑对您的id生成策略的影响,例如此处讨论.
更新2015-09-23
我终于找到了坐下来写一篇详细文章的时间,网址是https://frightanic.com/software-development/jpa-batch-inserts/.
使用save()会话中的方法,Hibernate将对象耦合到一行,并且在会话保持活动状态时该关系保持不变。因此,如果您使用同一对象,则实际上是更新现有行。解决方案是为每一行构造一个新对象。在这种情况下:
for (String item : items)
{
Feature feature = new Feature();
feature.setName(item);
session.save(feature);
}
Run Code Online (Sandbox Code Playgroud)