Пакетирование Hibernate не работает в проекте EJB/JPA

Я пытаюсь заставить пакетную обработку в спящем режиме работать, используя EJB, развернутые на сервере приложений Wildfly, используя postgres для сохранения.

Кажется, независимо от того, какую конфигурацию я использую, и как просто я создаю обновления, Hibernate НЕ будет пакетировать вставки. Я использую:

  • Java 8
  • Wildfly 10.1 (Hibernate 5.0.10.Final)
  • Postgres 9.6 (драйвер JDBC PostgreSQL 42.2.5)

Я создал пример для сохранения нескольких строк довольно простого объекта. Я использую метод в существующем сессионном компоненте без сохранения состояния для запуска примера.

persistence.xml:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
   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">

    <persistence-unit name="bpcPAS">
        <jta-data-source>java:/jdbc/DB_bpcPAS</jta-data-source>
        <shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode>
        <properties>
            <property name="jboss.entity.manager.factory.jndi.name" value="persistence-units/bpcPAS" />
            <property name="hibernate.show_sql" value="false" />
            <property name="hibernate.connection.isolation" value="2" />
            <property name="hibernate.jdbc.batch_size" value="20" />
            <property name="hibernate.order_inserts" value="true" />
            <property name="hibernate.order_updates" value="true" />
            <property name="hibernate.default_schema" value="pas"/>
            <property name="hibernate.cache.use_second_level_cache" value="true"/>
        </properties>
    </persistence-unit>
</persistence>

Простой компонент FxRate Entity:

public class FxRate implements Serializable {

    @Embeddable
    public static class FxRatePK implements Serializable {

        /**
         * Currency Type
         */
        @Enumerated(EnumType.STRING)
        @Column(name="CURRENCY_TYPE")
        private CurrencyType currencyType = null;

        /**
         * Price date
         */
        @Column(name="PRICE_DATE")
        @org.hibernate.annotations.Type(type = "org.jadira.usertype.dateandtime.joda.PersistentLocalDate")
        private LocalDate priceDate;

        public FxRatePK() {}

        public FxRatePK(CurrencyType currencyType, LocalDate priceDate) {
            super();
            this.currencyType = currencyType;
            this.priceDate = priceDate;
        }

        @Override
        public int hashCode() {
            final int prime = 31;
            int result = 1;
            result = prime * result + ((currencyType == null) ? 0 : currencyType.hashCode());
            result = prime * result + ((priceDate == null) ? 0 : priceDate.hashCode());
            return result;
        }

        @Override
        public boolean equals(Object obj) {
            if (this == obj)
                return true;
            if (obj == null)
                return false;
            if (getClass() != obj.getClass())
                return false;
            FxRatePK other = (FxRatePK) obj;
            if (currencyType != other.currencyType)
                return false;
            if (priceDate == null) {
                if (other.priceDate != null)
                    return false;
            } else if (!priceDate.equals(other.priceDate))
                return false;
            return true;
        }

        public CurrencyType getCurrencyType() {
            return currencyType;
        }

        public void setCurrencyType(CurrencyType currencyType) {
            this.currencyType = currencyType;
        }

        public LocalDate getPriceDate() {
            return priceDate;
        }

        public void setPriceDate(LocalDate priceDate) {
            this.priceDate = priceDate;
        }
    }

    /**
     * Primary key
     */
    @EmbeddedId
    protected FxRatePK pk;

    /**
     * Price 
     */
    @Column(name="PRICE", precision=15, scale=10)
    @Type(type = "com.silver.bpc.common.hibernate.NumericType")
    private Double price;

    /**
     * Default Constructor
     */
    public FxRate() {}

    /**
     * Constructor
     * @param currType
     * @param priceDate
     * @param price
     */
    public FxRate(CurrencyType currType, LocalDate priceDate, Double price) {
        this.pk = new FxRatePK(currType, priceDate);
        this.price = price;
    }

    public CurrencyType getCurrencyType() {
        return pk.currencyType;
    }

    public LocalDate getPriceDate() {
        return pk.priceDate;
    }

    public Double getPrice() {
        return price;
    }

    public void setPrice(Double price) {
        this.price = price;
    }
}

Пример запускаемого кода (с помощью менеджера сущностей bpcPAS "em"):

LocalDate date = new LocalDate();

for (int i=0; i<200; i++) {
    FxRate fxRate = new FxRate(CurrencyType.EUR, date.minusDays(i), 1.0);
    em.persist(fxRate);
}
em.flush();
em.clear();

В этом примере hibernate должен создать 10 операторов вставки, каждая из которых вставляет 20 строк. В отладочной информации говорится, что выполняется пакет размером 20, но фактические операторы, выводимые в журнал, указывают на обратное. Времена, выполненные с использованием разных размеров пакетов, дают одинаковый результат, указывая на то, что вставки отправляются по одному (как показывает журнал):

2019-04-04 13:00:12,608 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,615 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,616 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,618 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,619 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,621 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,622 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,624 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,626 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,627 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,629 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,630 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,632 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,634 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,636 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,637 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,639 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,640 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,642 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,643 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,645 DEBUG [org.hibernate.engine.jdbc.batch.internal.BatchingBatch] (default task-6) Executing batch size: 20
2019-04-04 13:00:12,648 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,650 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,651 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,653 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,654 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,656 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,657 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,659 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,660 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,662 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,664 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,665 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,667 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,668 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,670 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,671 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,673 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,674 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,675 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,677 DEBUG [org.hibernate.SQL] (default task-6) insert into pas.FX_RATE (PRICE, CURRENCY_TYPE, PRICE_DATE) values (?, ?, ?)
2019-04-04 13:00:12,678 DEBUG [org.hibernate.engine.jdbc.batch.internal.BatchingBatch] (default task-6) Executing batch size: 20
...

Спасибо за любую помощь, вы можете предоставить!!!

0 ответов

Другие вопросы по тегам