0

我正在使用ireport-4.5.0,spring3.0.5RELEASE,jpa2. 我有一个名为 User 的实体类,其属性如下 userId、userName、password.I

通过将字段指定为这三个属性名称来设计 jrxml。如果我将 jpa 查询指定为 From USer,那么它可以正常工作并给出结果。但我想要用户名的不同值(用户名列也允许重复值)所以我将 jpaQuery 设为

SELECT userId,DISTINCT(userName),password FROM User 

然后我没有得到结果。查询有什么问题。

嗨,我在这里给出我正在使用的代码

public User getUsers() throws Exception{
 Query uQuery = entityManager.createQuery("SELECT u.userId,u.userName,u.password FROM User u GROUP BY u.userId,u.userName,u.password");
       List <User>listOfUsers = uQuery.getResultList();
       if (listOfUsers == null) {
           throw new ResourceNotFound();
        }
       for (Iterator iterator = listOfUsers.iterator(); iterator.hasNext();) {
            User userList = (User)iterator.next();

        }

       return userList;

在这里,我得到 ClassCastException:java.lang.String 无法转换为 User。它在 for 循环语句中显示此异常。我是 JPA 的新手。您能否解释一下如何迭代该对象列表。

4

1 回答 1

1

您不能将 DISTINCT 放在 JPQL 或 SQL 中的单个列上。

您很可能需要使用 group by,

SELECT u.userId,u.userName,u.password FROM User u group by u.userId, u.userName, u.password

于 2012-05-08T13:23:34.837 回答