有什么方法可以删除特定命名查询的缓存吗?我并不是真的想删除所有查询...或者,是否有其他解决方法?
即使我使用普通的查询类,它也不能工作...
我正在使用hibernate 3.6,glassfish 3.1.1,这是一个java ee应用程序(代码来自ejb模块)。
我有这样的东西:
public User getUserByName(String username) {
try {
return (User) em.createNamedQuery("User.getUserByName").setParameter("username", username).getSingleResult();
} catch (NoResultException e) {
return null;
}
}
//...
if(getUserByName(entity.getUsername()!=null) {
em.persist(entity);
}
//...
// username added in database (checked)
if(getUserByName(entity.getUsername())==null) {
//something else
}我第二次用"getUserByName“又是..空...为什么?
我认为它是缓存模块(因为如果我设置我的提供者为eclipselink,它可以正常工作)……
我正在使用hibernate进行搜索..
发布于 2011-10-14 04:40:59
使用EclipseLink,您可以执行以下操作:
Query query = em.createNamedQuery("Users.findByUsername");
query.setHint("javax.persistence.cache.storeMode", "REFRESH");对于hibernate,提示是:要进一步阅读和理解,请使用"Override the cache mode for this query (例如CacheMode.REFRESH )“:old article
https://stackoverflow.com/questions/7699693
复制相似问题