java – Hibernate JDBC批量大小不起作用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java – Hibernate JDBC批量大小不起作用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3037字,纯文字阅读大概需要5分钟。
内容图文
我正在使用SpringFramework 3和Hibernate 4以及MySQL 5和jpa.我的测试代码看起来像……
@Repository
public class TestRepositoryImpl implements TestRepository {
@PersistenceContext
private EntityManager em;
@Override
@Transactional
public void insertBulk() {
Item it;
for(int i= 0; i<1000;i++) {
it = new Item();
it.setPrice(Math.random()*100);
em.persist(it);
}
}
}
我的弹簧配置
<bean id="entityManagerFactory"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitName" value="application" />
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
我的persistence.xml
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
version="1.0">
<persistence-unit name="application" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.springapp.test.domain.Item</class>
<class>com.springapp.test.domain.Order</class>
<exclude-unlisted-classes>true</exclude-unlisted-classes>
<properties>
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.format_sql" value="false" />
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" />
<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/testdb" />
<property name="hibernate.connection.username" value="root" />
<property name="hibernate.connection.password" value="" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />
<property name="hibernate.hbm2ddl.auto" value="update" />
<property name="hibernate.jdbc.batch_size" value="20" />
</properties>
</persistence-unit>
</persistence>
当我调用运行我的代码时,它将触发插入查询1000次而不是触发50插入查询.有什么问题?
请帮助我使用hibernate在jpa中批量插入
解决方法:
请注意,如果插入表的主键是GenerationType.Identity,Hibernate将透明地禁用JDBC级别的插入批处理.
save()只有一个记录,然后是flush(),因此每次刷新只需要处理一个INSERT SQL.这就是Hibernate无法帮助您批量插入的原因,因为只有一个INSERT SQL需要处理.在调用flush()之前,应该将()保存到最多一定数量的记录,而不是为每个save()调用flush().
批量插入的最佳做法是这样的:
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
for ( int i=0; i<888888; i++ ) {
TableA record = new TableA();
record.setXXXX();
session.save(record)
if ( i % 50 == 0 ) { //50, same as the JDBC batch size
//flush a batch of inserts and release memory:
session.flush();
session.clear();
}
}
tx.commit();
session.close();
您可以批量保存和刷新记录.在每个批处理结束时,您应该清除持久性上下文以释放一些内存以防止内存耗尽,因为每个持久对象都放在第一级缓存(您的JVM内存)中.您还可以禁用二级缓存以减少不必要的开销.
请检查此链接http://docs.jboss.org/hibernate/orm/3.5/reference/en/html/batch.html
内容总结
以上是互联网集市为您收集整理的java – Hibernate JDBC批量大小不起作用全部内容,希望文章能够帮你解决java – Hibernate JDBC批量大小不起作用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。