java - EclipseLink 的 CacheRetrieveMode.BYPASS 没有用

标签 java jpa eclipselink

按照我的代码操作:

Company cc = em.find(Company.class, clientUser.getCompany().getId());
System.out.println(cc.getCompany_code());

HashMap findProperties = new HashMap();
findProperties.put(QueryHints.CACHE_RETRIEVE_MODE, CacheRetrieveMode.BYPASS);

Company oo = em.find(Company.class, clientUser.getCompany().getId(), findProperties);
System.out.println(oo.getCompany_code());

就像示例“用作 EntityManager 属性”一样。 here

但是,两个输出之间没有任何不同。

最佳答案

您期望有何不同?为什么?

请注意,CACHE_RETRIEVE_MODE 仅影响共享(二级)缓存,而不影响持久性上下文(一级缓存/事务性缓存),对于已读取的对象,必须始终在持久性上下文中维护对象标识。

如果您更改了数据库,并期望新数据,请尝试使用新的 EntityManager 绕过,或尝试使用刷新()。

EclipseLink 还提供查询提示“eclipselink.maintain-cache”=“false”来绕过持久性上下文。

您使用的 EclipseLink 版本是什么?我相信 2.0 版本中的 BYPASS 存在一个错误,该错误已在 2.1 中修复。尝试最新版本。

关于java - EclipseLink 的 CacheRetrieveMode.BYPASS 没有用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4462340/

相关文章:

java - 在 netbeans 中同时运行多个 java 主类

java - EclipseLink 在 Oracle DB 上生成重复的主键

java - 更新时嵌入的 AttributeOverride 不起作用

java - 从坐标获取城市名称

java.lang.OutOfMemory错误: Java heap space

database - 使用 eclipselink jpa 从数据库加载列表

java - 如何处理 spring jpa @transactional 和 catch block 中的新插入

java - JPA 复合主键

java - 使用 EclipseLink

java - 我没有在 webhook url 中使用 stripe 获取任何事件