我使用的是jinq版本1.8.11,hibernate版本4.3使用hibernate会话工厂,而不是实体管理器。
我正在尝试以下查询:
JPAJinqStream<Routine> routineStream = stream.streamAll(getCurrentSession(), Routine.class);
if (text.isPresent()) {
final String searchText = text.get();
routineStream = routineStream
.leftOuterJoin(
(r, source) -> source.stream(NLSProperty.class),
(r, nls) -> nls.getVarKey().equals("routine.100.title")
).select(pair -> pair.getOne());"%" + searchText + "%")).select(Pair::getOne);
}
List<Routine> tp = routineStream.toList();当变量文本不存在时,查询工作正常,我将得到结果。当变量文本出现时,我将得到以下错误:
java.lang.IllegalStateException: DOT node with no left-hand-side!知道我做错什么了吗?
我已经调试了jinq,它生成的查询如下所示:
SELECT A FROM de.etherapists.ehealth.model.routine.Routine A LEFT OUTER JOIN de.etherapists.ehealth.model.NLSProperty B ON B.varKey = 'routine.100.title';谢谢
发布于 2018-11-29 12:50:10
好的,我将hibernate版本升级到5.1,仍然使用会话工厂,而不是实体管理器。
现在的代码是:
if (text.isPresent()) {
routineStream = routineStream
.leftOuterJoin(
(routine, source) -> source.stream(NLSProperty.class),
(routine, nls) -> routine.getTitle().equals(nls.getVarKey())
)
.where(pair -> JPQL.like(pair.getOne().getShortCode(), "%" + text + "%")
|| JPQL.like(pair.getTwo().getVarValue(), "%" + text + "%"))
.select(Pair::getOne)
}它就像一种魅力
https://stackoverflow.com/questions/53517692
复制相似问题