JPA更新查询:缓存未正确失效
为什么它不起作用:JPA更新查询:缓存未正确失效,jpa,caching,eclipselink,Jpa,Caching,Eclipselink,为什么它不起作用: @Test public void test() { EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory("test-pu"); EntityManager entityManager = entityManagerFactory.createEntityManager(); String id = "id"; long value
@Test
public void test() {
EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory("test-pu");
EntityManager entityManager = entityManagerFactory.createEntityManager();
String id = "id";
long value = 1234L;
entityManager.getTransaction().begin();
FancyEntity fancyEntity = new FancyEntity(id);
entityManager.persist(fancyEntity);
int updateCount = entityManager.createQuery("update FancyEntity item set item.value = ?2 where item.id = ?1").setParameter(1, id).setParameter(2, value).executeUpdate();
assertEquals(1, updateCount);
FancyEntity checkResult = entityManager.find(FancyEntity.class, id);
assertEquals(1234L, checkResult.getValue()); // <- this assert fails
entityManager.getTransaction().commit();
}
及
似乎有一些缓存没有被更新查询失效checkResult
和fancyEntity
是同一个对象。使用entityManager.refresh(检查结果)
强制刷新。最奇怪的是,发出了一个select
,用于检索checkResult
(见eclipselink日志),但仍然没有考虑其结果。使用MySQL而不是HSQL的行为相同
有什么可能出错的提示吗?这是一个批量更新语句,正如JPQL语言参考所指出的: 持久性上下文未与 批量更新或删除。执行大容量存储时应小心 更新或删除操作,因为它们可能导致不一致 在数据库和活动持久性中的实体之间 上下文。一般来说,批量更新和删除操作只应 在单独的交易中或交易开始时执行 事务(在访问状态可能为的实体之前) 受此类行动影响) ) 因此,你所看到的行为完全有道理
@Entity
public class FancyEntity {
@Id
private String id;
@Column
private long value;
public FancyEntity(String id) {
this.id = id;
this.value = 0;
}
public FancyEntity() {
}
public long getValue() {
return value;
}
}
<persistence-unit name="test-pu"
transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<class>com.fancypackage.FancyEntity</class>
<properties>
<property name="eclipselink.logging.level" value="SEVERE"/>
<property name="javax.persistence.jdbc.driver" value="org.hsqldb.jdbcDriver" />
<property name="javax.persistence.jdbc.url" value="jdbc:hsqldb:mem;sql.enforce_strict_size=true;hsqldb.tx=mvcc" />
<property name="eclipselink.ddl-generation" value="drop-and-create-tables" />
<property name="eclipselink.ddl-generation.output-mode" value="database" />
<property name="eclipselink.logging.level.sql" value="FINE"/>
<property name="eclipselink.logging.parameters" value="true"/>
</properties>
</persistence-unit>
java.lang.AssertionError:
Expected :1234
Actual :0