我想使用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;?
感谢您的帮助
答案 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));