Пакетирование 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
...
Спасибо за любую помощь, вы можете предоставить!!!