我是新JPA 2.0 Criteria API的第一次用户,当我需要将一个数字字段转换为String以将其与String参数进行比较时,我遇到了问题.原因是我想搜索部分数字,所以我在CriteriaBuilder上使用'like'.这是一个代码示例:
CriteriaBuilder cb = getEntityManager().getCriteriaBuilder();
CriteriaQuery<ParcelDO> cq = cb.createQuery(ParcelDO.class);
Root<ParcelDO> parcelDO = cq.from(ParcelDO.class);
cq.select(parcelDO);
String parcelNumberId = parcelSearchDetailDO.getParcelNumberId();
if (parcelNumberId != null && !parcelNumberId.isEmpty()) {
Predicate parcelNumberIdPredicate = cb.like(
parcelDO.<Long> get("parcelNumberId").as(String.class),
parcelNumberId + "%");
if (cq.getRestriction() != null) {
cq.where(cq.getRestriction(), parcelNumberIdPredicate);
} else {
cq.where(parcelNumberIdPredicate);
}
}
Run Code Online (Sandbox Code Playgroud)
重要的是
Predicate parcelNumberIdPredicate = cb.like(
parcelDO.<Long> get("parcelNumberId").as(String.class),
parcelNumberId + "%");
Run Code Online (Sandbox Code Playgroud)
我使用Criteria API将Path转换为CriteriaBuilder上like方法所需的表达式.
现在,当我运行并执行此代码时,基础JPA 2.0实现Hibernate失败,出现以下异常:
Caused by: org.hibernate.hql.ast.QuerySyntaxException:
expecting CLOSE, found '(' near line 1, column 117
[select generatedAlias0 from domain.ParcelDO …Run Code Online (Sandbox Code Playgroud)