2

有什么区别:

  • 标准Builder.in(谓词);
  • 条件查询.where(谓词);

这似乎给出了相同的结果。我错过了什么吗?我们应该选择查询上方的构建器吗?

完整示例:

List<String> names = new ArrayList<String>();
names.add("John");
names.add("Emma");

CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<PersonEntity> criteriaQuery = criteriaBuilder.createQuery(PersonEntity.class);
Root<PersonEntity> root = criteriaQuery.from(PersonEntity.class);

Predicate predicate = root.get(PersonEntity_.name).in(names);
criteriaBuilder.in(predicate);
// or alternative: criteriaQuery.where(predicate);

List<PersonEntity> list = entityManager.createQuery(cq).getResultList();
4

1 回答 1

2

criteriaBuilder.in(predicate) 创建一个新的谓词。如果将谓词添加到查询中,您应该向您的提供者提交错误,因为这将不可移植。根据规范,它创建一个新的谓词,就像 root.get(PersonEntity_.name).in(names) 一样。查询仅应在添加到谓词时使用谓词,例如通过调用条件查询.where(谓词)。

于 2014-01-27T15:34:12.633 回答