Я попытался настроить размер пакета JDBC, как упоминалось в блоге @Vlad Mihalcea https: / /vladmihalcea.com/how-to-customize-the-jdbc-batch-size-for-each-persistence-context-with-hibernate/
EntityManager entityManager = entityManagerFactory.createEntityManager();
entityManager.getTransaction().begin();
entityManager.unwrap(Session.class).setJdbcBatchSize(5);
for(int i = 0;i<10;i++){
Charge c = new Charge();
c.setAccountNumber("acct"+i);
entityManager.persist(c);
}
entityManager.getTransaction().commit();
<bean id="entityManagerFactoryDefault"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="charg" />
<property name="persistenceUnitName" value="MaterializedView" />
<property name="persistenceXmlLocation" value="classpath*:META-INF/jpa-persistence.xml" />
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="generateDdl" value="false" />
<property name="showSql" value="true"/>
<property name="database">
<util:constant static-field="org.springframework.orm.jpa.vendor.Database.ORACLE" />
</property>
</bean>
</property>
<property name="jpaProperties">
<props>
<prop key="hibernate.default_batch_fetch_size">500</prop>
<prop key="hibernate.jdbc.fetch_size">10</prop>
<prop key="hibernate.jdbc.batch_versioned_data">true</prop>
<prop key="hibernate.order_updates">true</prop>
<prop key="hibernate.order_inserts">true</prop>
<prop key="hibernate.jdbc.batch_size">30</prop>
<prop key="hibernate.id.new_generator_mappings">false</prop>
</props>
</property>
</bean>
Но это вызывает 10 запросов на вставку.
Я получаю эти запросы Hibernate: выберите charge.nextval из двойного Hibernate: вставьте в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?) Hibernate: вставьте в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?) Hibernate: вставьте в CHARGE (ACCOUNTNUMBER CHARGE_ID ) значения (?,?) Спящий режим: вставить в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?) Спящий режим: вставить в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?) Спящий режим: вставить в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?, ?) Гибернация: вставка в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?) Гибернация: вставка в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?) Гибернация: вставка в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?) Гибернация: вставка в значения CHARGE (ACCOUNTNUMBER CHARGE_ID) (?,?)
Я использую hibernate 5.2.10. Окончательную версию и последовательность в качестве стратегии. Может ли кто-нибудь исправить меня, если что-то не так в моем коде
1 ответ
Механизм ведения журнала Hibernate мог ввести вас в заблуждение. Трудно увидеть, как пакетная обработка JDBC работает с ведением журнала Hibernate по умолчанию.
Если вы переключитесь на datasource-proxy, то увидите, как работает пакетная обработка:
Name:DATA_SOURCE_PROXY, Time:6, Success:True,
Type:Prepared, Batch:True, QuerySize:1, BatchSize:3,
Query:["insert into post (title, version, id) values (?, ?, ?)"],
Params:[(Post no. 0, 0, 0), (Post no. 1, 0, 1), (Post no. 2, 0, 2)]
Параметр Batch:True
показывает, что перехват JDBC работает, а BatchSize:3
показывает, что у вас есть наборы значений параметров, которые отправляются в одном цикле обработки базы данных.
Похожие вопросы
Новые вопросы
java
Java - это язык программирования высокого уровня. Используйте этот тег, если у вас возникли проблемы с использованием или пониманием самого языка. Этот тег редко используется отдельно и чаще всего используется вместе с [spring], [spring-boot], [jakarta-ee], [android], [javafx], [hadoop], [gradle] и [maven].