1

JPQLクエリが期待どおりに返されない理由を理解するのに約2時間費やしました。コードを検討してください:

    System.out.println("JPQL ----------------------------");
    Query q = em.createQuery(
            "select u.userName, count(p.id) from User u " + 
            "left join u.posts p group by u.userName");
    List x = q.getResultList();     
    for(Object o : x) {
        Object[] y = (Object[])o;
        System.out.printf("%s %s\n", y[0], y[1]);
    }

    System.out.println("Spring Data JPA -----------------");
    for(User user : userRepository.findAll()) {
        List<Post> posts = postRepository.findAllByAuthor(user);
        System.out.printf("%s %s\n", user.getUserName(), posts.size());
    }

出力は次のとおりです。

JPQL ----------------------------
user1 0
user2 0
Spring Data JPA -----------------
user1 3
user2 10

JPQLのアプローチは、リポジトリのアプローチと同じように出力されると思います。間違いはどこですか?

アップデート

SQLトレースの内容は次のとおりです。

select 
  user0_.userName as col_0_0_, 
  count(post2_.id) as col_1_0_ 
from User user0_ 
left outer join User_Post posts1_ 
  on user0_.id=posts1_.User_id 
left outer join Post post2_ 
  on posts1_.posts_id=post2_.id 
group 
  by user0_.userName
4

1 に答える 1

1

クエリは正しかったのですが、関係の定義に問題がありました。これが私が持っていたものです:

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    ...         
    @OneToMany
    private List<Post> posts;
    ...
}

@Entity
public class Post {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    ...
    @ManyToOne
    private User author;
    ...
}

と の関係を次のUserように指定する必要があるPostようです。

    @OneToMany(mappedBy = "author")
    private List<Post> posts;
于 2013-02-07T05:35:13.847 に答える