Spring Data JPA:从不同的表

时间:2017-05-25 04:36:58

标签: spring spring-data-jpa hibernate-criteria

我正在尝试构建一个规范来为下面的查询预测子查询。 从用户u中选择u。*,其中u.login in(从userRoles ur中选择ur.role_id,其中ur.role_Id = roleId)。

到目前为止,这是我建立的部分

public static Specification<User> userRoleId(String roleId) {
        return new Specification<User>() {
            @Override
            public Predicate toPredicate(Root<User> root, CriteriaQuery<?> query, CriteriaBuilder builder) {
                //return builder.equal(root.<LocalDate> get("scheduledDisbursementDate"), scheduledDisbursementDate);
                Subquery<UserRole> subquery = query.subquery(UserRole.class);
                Root<UserRole> subqueryRoot = subquery.from(UserRole.class);
                subquery.select(subqueryRoot);
                Predicate roleIdList = builder.equal(subqueryRoot.get("roleId"), roleId);
                subquery.select(subqueryRoot).where(roleIdList);
                return builder.exists(subquery);
            }
        };
    }

请你帮我把子查询与主查询联系起来。

注意:实体类中没有定义连接。 evrything应该只通过subquerys来完成

1 个答案:

答案 0 :(得分:2)

找到答案

第一个谓词将加入UserRole userId列和User表登录列。 第二个谓词将根据roleId过滤条件。

public static Specification<User> userRoleId(String roleId) {
    return new Specification<User>() {
        @Override
        public Predicate toPredicate(Root<User> root, CriteriaQuery<?> query, CriteriaBuilder builder) {
            Subquery<UserRole> subquery = query.subquery(UserRole.class);
            Root<UserRole> subqueryRoot = subquery.from(UserRole.class);
            subquery.select(subqueryRoot);
            Predicate userIdPredicate = builder.equal(subqueryRoot.get("userId"), root.<String> get("login"));
            Predicate rolePredicate = builder.equal(subqueryRoot.get("roleId"), roleId);
            subquery.select(subqueryRoot).where(userIdPredicate, rolePredicate);
            return builder.exists(subquery);

        }
    };
}