Sql Spring数据JPA-具有多个条件的左连接
我需要在…上使用Sql Spring数据JPA-具有多个条件的左连接,sql,jpa,spring-data-jpa,criteria-api,Sql,Jpa,Spring Data Jpa,Criteria Api,我需要在…上使用联接表进行联接。。。和…使用Spring数据JPA标准生成器 我知道我可以做这样的基本连接: Join<ReportEntity, ProductEntity> productJoin = root.join("products", JoinType.LEFT); 请注意,在上述查询的WHERE子句中指定p.rare=1并不能给出所需的结果,它需要进入ON子句中。Join-productJoin=root.Join(“products”,Join
联接表进行联接。。。和…
使用Spring数据JPA标准生成器
我知道我可以做这样的基本连接:
Join<ReportEntity, ProductEntity> productJoin = root.join("products", JoinType.LEFT);
请注意,在上述查询的WHERE
子句中指定p.rare=1
并不能给出所需的结果,它需要进入ON
子句中。Join-productJoin=root.Join(“products”,JoinType.LEFT);
Join<ReportEntity, ProductEntity> productJoin = root.join("products", JoinType.LEFT);
Predicate joinPredicate = criteriaBuilder.equal(root.get("id"), productJoin.get("reportId"));
Predicate rarePredicate = criteriaBuilder.equal(productJoin.get("rare"), 1);
productJoin.on(joinPredicate, rarePredicate);
谓词joinPredicate=criteriaBuilder.equal(root.get(“id”)、productJoin.get(“reportId”);
谓词rarePredicate=criteriaBuilder.equal(productJoin.get(“稀有”),1);
productJoin.on(joinPredicate,rarePredicate);
Join<ReportEntity, ProductEntity> productJoin = root.join("products", JoinType.LEFT);
Predicate joinPredicate = criteriaBuilder.equal(root.get("id"), productJoin.get("reportId"));
Predicate rarePredicate = criteriaBuilder.equal(productJoin.get("rare"), 1);
productJoin.on(joinPredicate, rarePredicate);