【问题标题】:JPA customize the JDBC batch size is not workingJPA 自定义 JDBC 批处理大小不起作用
【发布时间】:2017-12-10 14:32:54
【问题描述】:

我尝试按照@Vlad Mihalcea 博客中的说明配置 JDBC 批处理大小 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 个插入查询。

我得到这个查询 休眠:从双重选择charge.nextval 休眠:插入 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) 值 (?, ?) 休眠:插入 CHARGE (ACCOUNTNUMBER CHARGE_ID) 值 (?, ?) Hibernate:插入CHARGE(ACCOUNTNUMBER CHARGE_ID)值(?,?)

我正在使用休眠 5.2.10.Final 版本和序列作为策略。 如果我的代码有问题,有人可以纠正我

【问题讨论】:

    标签: java hibernate jpa orm


    【解决方案1】:

    Hibernate 日志记录机制可能在此处误导了您。很难看到使用默认 Hibernate 日志记录的 JDBC 批处理工作。

    如果你切换到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 显示您有一组在一次数据库往返中发送的参数值。

    【讨论】:

      猜你喜欢
      • 2014-02-12
      • 2014-01-19
      • 2015-03-07
      • 1970-01-01
      • 2018-05-19
      • 2013-11-22
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多