我正在使用 userDetailsManager 创建新用户,并以正确的方式尝试从数据库获取 MyUser 对象。这是一个例子:
User user = new User(username, passwordHash, Arrays.asList(new SimpleGrantedAuthority("ROLE_USER")));
userDetailsManager.createUser(user);
MyUser current = users.findByUsername(user.getUsername());
<小时/>
public MyUser findByUsername(String username) {
TypedQuery<MyUser> query = entityManager.createQuery(
"select u from User u where u.username = :username", User.class);
query.setParameter("username", username);
return query.getResultList().get(0);
}
并且它总是返回 null。
正在检查数据库 - 一切都已就位。 为什么?
最佳答案
您应该调用EntityManager#flush
在执行插入之后。记录可能会刷新到数据库中,但 EM 缓存可能尚未刷新,因此这就是您收到此结果的原因。
您还应该使用 getSingleResult
而不是 getResultList
。
关于java - 创建用户对象后无法正确获取它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37277305/