Java Spring数据JPA@Query注释有问题(SQL语法错误)

Java Spring数据JPA@Query注释有问题(SQL语法错误),java,hibernate,spring-data-jpa,spring-data,jpql,Java,Hibernate,Spring Data Jpa,Spring Data,Jpql,编辑:我想检查某个用户是否在组中拥有权限。如果有更好的解决方案而不询问他的所有权限,请告诉我 以下查询提供了一个我无法理解的错误: @Repository public interface PrivilegeRepository extends JpaRepository<Privilege, Long> { @Query("select p from Privilege p " + "inner join p.userTypes " +

编辑:我想检查某个用户是否在组中拥有权限。如果有更好的解决方案而不询问他的所有权限,请告诉我

以下查询提供了一个我无法理解的错误:

@Repository
public interface PrivilegeRepository extends JpaRepository<Privilege, Long> {

    @Query("select p from Privilege p " +
            "inner join p.userTypes " +
            "inner join UserGroup u " +
            "where u.user.id=:uid and u.group.id=:gid")
    List<Privilege> getPrivilegesOfUser(@Param("uid") Long uid, @Param("gid") Long gid);

}
用户组实体

@Entity
@Table(name = "user_to_group")
public class UserGroup {

    @EmbeddedId
    private UserGroupId id;

    @ManyToOne(fetch = FetchType.LAZY,
            cascade = {CascadeType.DETACH, CascadeType.MERGE,
                    CascadeType.REFRESH, CascadeType.PERSIST})
    @MapsId("userId")
    @JoinColumn(name = "user_id", insertable = false, updatable = false)
    private User user;

    @ManyToOne(fetch = FetchType.LAZY,
            cascade = {CascadeType.DETACH, CascadeType.MERGE,
                    CascadeType.REFRESH, CascadeType.PERSIST})
    @MapsId("groupId")
    @JoinColumn(name = "group_id", insertable = false, updatable = false)
    private Group group;

    @ManyToOne(fetch = FetchType.LAZY,
            cascade = {CascadeType.DETACH, CascadeType.MERGE,
                    CascadeType.REFRESH, CascadeType.PERSIST})
    @JoinColumn(name = "user_type_id")
    private UserType userType;

    @Column(name = "is_blocked",
    insertable = false)
    private boolean isBlocked = false;
我首先在MYSQL工作台中尝试了等效的查询,结果很好。与Jpa存储库实现无关。 这是在MYSQL上工作的代码:

select p.name from privilege p 
    inner join user_type_to_privilege utp 
        on p.id=utp.privilege_id
    natural join user_to_group utg
    where utg.user_id=16 and
        utg.group_id=9;
这就是我使用的方言:
spring.jpa.properties.hibernate.dialent=org.hibernate.dialent.mysqldialent

这是过时的还是什么?

问题出在第二个内部联接上。它不明确,不知道要为联接匹配哪个列。 有效的查询:

@Query("select p from Privilege p " +
            "inner join p.userTypes t " +
            "inner join UserGroup u on t.id=u.userType.id "+
            "where u.user.id=:uid and u.group.id=:gid")
    List<Privilege> getPrivilegesOfUser(@Param("uid") Long uid, @Param("gid") Long gid);
@Query(“从特权p中选择p”+
“内部联接p.userTypes t”+
“t.id=u.userType.id上的内部联接用户组u”+
“其中u.user.id=:uid和u.group.id=:gid”)
列出getPrivilegesOfUser(@Param(“uid”)Long-uid、@Param(“gid”)Long-gid);

您的JPQL查询解析并编译为无效的MySQL查询,但它不应该这样做。打开
org.hibernate.SQL
trace
级别的日志记录,以获取生成的查询并在中提交错误报告。如果它是一个无效的JPQL查询(可能没有显式的连接条件),那么它应该在到达数据库之前失败。
@Query("select p from Privilege p " +
            "inner join p.userTypes t " +
            "inner join UserGroup u on t.id=u.userType.id "+
            "where u.user.id=:uid and u.group.id=:gid")
    List<Privilege> getPrivilegesOfUser(@Param("uid") Long uid, @Param("gid") Long gid);