jpa criteriabuilder upper给出了编译错误

时间:2014-07-17 16:58:28

标签: java hibernate jpa

我想使用CriteriaBuilder进行不区分大小写的查询,如hibernate jpa criteriabuilder ignore case queries所述以及网络上的许多其他问题和教程。

我的代码是:

public Predicate toPredicate(Root<User> root, CriteriaQuery<?> query, CriteriaBuilder builder) {
    return builder.equal(builder.upper(root.get("firstName")), "test".toUpperCase());
}

但我收到编译时错误:

  

CriteriaBuilder类型中的upper(Expression&lt; String&gt;)方法不适用于参数(Path&lt; Object&gt;)

我使用的hibernate jpa的版本是:

<groupId>org.hibernate.javax.persistence</groupId>
<artifactId>hibernate-jpa-2.1-api</artifactId>
<version>1.0.0.Final</version>

它取决于我使用的休眠版本吗?如何放置表达式&lt; String&gt;而不是Path&lt; Object&gt;?

感谢您的帮助

2 个答案:

答案 0 :(得分:14)

正如编译器所说我们期望在这种情况下表达式Path从Expression扩展但是你有一个路径来解决这个问题,原因如下。

return builder.equal(builder.upper(root.<String> get("firstName")), "test".toUpperCase());

在get方法之前添加<String>,希望有所帮助。

答案 1 :(得分:-2)

类型为upper(Expression<String>)的方法CriteriaBuilder不适用于参数(Path<Object>

您可以使用:

 Expression expression =cb.lower(root.get("column"));
 query.select(expression .as(yourTypeClass.class));