我试图用JSON_VALUE功能克里特标准API查询()是Oracle12c:JPA标准API与oracle12c JSON_VALUE功能
select * from orderswhere (JSON_VALUE(duty, '$.department') in (? , ? , ? ,? , ? , ? , ?));
MODEL:
@Entity
@Table(name = "orders")
@EntityListeners(AuditingEntityListener.class)
public class Trade implements Serializable {
@Convert(converter = JpaConverterJson.class)
private Map<String, Object> duty;
.....
}
private Specification<InvoicePurchase> reportFormToSpec(Map<String, Object>
params) {
return (root, query, cb) -> {
List<Predicate> predicates = new ArrayList<>();
if (!StringUtils.isEmpty(params.get("department"))) {
Predicate predicate = cb.like(cb.function("json_value", String.class,
root.get("duty"),
cb.literal("$.department"))
, params.get("department"));
predicates.add(predicate);
}
return query.where(predicates.toArray(new Predicate[predicates.size()])).getRestriction();
};
}
但是,得到的异常:ohengine。 jdbc.spi.SqlExceptionHelper:ORA-40454:路径表达式不是文字
我在网上搜索了很长时间。但没用。请帮助或尝试提供一些想法如何实现这一点。
ERROC CODE:
2017-11-23 12:26:55.271 WARN 11972 --- [nio-8080-exec-1] o.h.engine.jdbc.spi.SqlExceptionHelper : SQL Error: 40454, SQLState: 99999
2017-11-23 12:26:55.271 ERROR 11972 --- [nio-8080-exec-1] o.h.engine.jdbc.spi.SqlExceptionHelper : ORA-40454: path expression not a literal
错误消息:2017-02-15 14:22:13.210 WARN 23176 --- [nio-8080-exec-7] ohengine.jdbc.spi.SqlExceptionHelper:SQL错误:40454,SQLState:99999 2017- 02-15 14:22:13.210 ERROR 23176 --- [nio-8080-exec-7] ohengine.jdbc.spi.SqlExceptionHelper:ORA-40454:路径表达式不是文字 –