2016-07-15 73 views
0

当我调用createQuery(String,Class)应用程序挂起时。 Hibernate的最后一个INFO是“使用ASTQueryTranslatorFactory”,但没有任何反应。下面是代码:使用JPQL的createQuery挂起

public User getUserByLogin(String username) { 
    String queryString = "SELECT u FROM USERS u WHERE u.USERNAME = :username"; 
    TypedQuery<User> query = entityManager.createQuery(queryString, User.class); 
    return query.setParameter("username", username).getSingleResult(); 
} 

它挂在TypedQuery<User> query = entityManager.createQuery(queryString, User.class);

但是,什么是有趣的,当我改变身体的方法是这样的:

public User getUserByLogin(String username) { 
    CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); 
    CriteriaQuery<User> criteriaQuery = criteriaBuilder.createQuery(User.class); 
    Root<User> userRoot = criteriaQuery.from(User.class); 
    criteriaQuery.select(userRoot).where(criteriaBuilder.equal(userRoot.get("username"), username)); 
    TypedQuery<User> query = entityManager.createQuery(criteriaQuery); 
    return query.getSingleResult(); 
} 

它工作正常。同样的环境,只是不同的方法。我错过了什么?

回答

1

为什么的FROM USERS u代替FROM USER u

+0

用户来说是数据库表名。 – Franek

+0

是的,那是什么错误。使用JPQL,您需要查询实体名称而不是表名。 –