1

假设我与 Person 实体有一个双向 1-1 关联

@Entity
public class Person {
  @OneToOne(optional=false)
  @JoinColumn(name = "contact_id")
  private Contact contact;


  // getters/setters/constructors
}

和联系实体

@Entity
public class Contact {
  @OneToOne(mappedBy="contact")
  private Person person;

  // getters/setters/
}

我找不到使用联系人实体为人员实体选择父对象的方法。像这样...

criteriaQuery.select(root.get(Contact_.person));

我收到此错误:

不兼容的类型。必选<? 扩展 ?> 的捕获,但“get”被推断为 Path<Y>:不存在类型变量的实例,因此 Person 符合捕获的 ?

有没有办法做到这一点?我想使用 Contact 根返回 Person Entity 的谓词。例如。

public static Specification<Person> phoneWithCountryCode(String countryCode) {
    return new Specification<Person>() {
        @Override
        public Predicate toPredicate(
            Root<Contact> root,
            CriteriaQuery<?> criteriaQuery,
            CriteriaBuilder criteriaBuilder
        ) {
            String startsWithPattern = countryCode + "%";
            criteriaQuery.select(root.get(Contact_.person));
            return criteriaBuilder.like(
                root.get(Contact_.phone), startsWithPattern
            );
        }
    };
}
4

1 回答 1

0

是的,你可以做到。我做到了。我有关系(书-评论)。

在您的情况下,创建Specification<Person>并使用 join with contact。像这样,

Join joins = root.join("contact");

如果需要帮助,请遵循我的代码。

public class BookSpecification {

    public static Specification<Book> getBookByNameAndReviewId(){

        return new Specification<Book> () {

            @Override
            public Predicate toPredicate(Root<Book> root, CriteriaQuery<?> query, CriteriaBuilder cb) 
            {
             //List<javax.persistence.criteria.Predicate>
            List<Predicate> predicates = new ArrayList<>();
            predicates.add(cb.equal(root.get("name"), "spring boot"));
            Join joins = root.join("reviews");
            predicates.add(cb.equal(joins.get("no") , 584));

                return cb.and(predicates.toArray(new Predicate[predicates.size()]));
            // return cb.equal(root, predicates);
            }

        };
    }
}
于 2018-08-10T11:50:54.410 回答