Spring Data Jpa Specification 调用Oracle 函数/方法
Posted inwcl
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring Data Jpa Specification 调用Oracle 函数/方法相关的知识,希望对你有一定的参考价值。
开发框架用的Jpa,数据库是 Oracle。
在开发中难免会遇到需要数据库字段是字符串格式,但是又需要对其进行范围查询(数据库设计问题,后续应避免).那么问题来了, Jpa Specification怎么查询呢?
if(StrUtil.isNotBlank(planStartDate)){
//调用Oracle方法,第一个参数是方法名称,第二个是返回数据类型,后续的是参数,可以多个
Expression<Date> function = criteriaBuilder.function("to_date" , Date.class,
root.get("planStartDate"), criteriaBuilder.literal("YYYY-MM-DD"));
//得到Expression 就可以进行后续操作了
Predicate predicate = criteriaBuilder.greaterThan(function, DateUtil.parse(planEndDate));
predicates.add(predicate);
}
生成的sql如下
select
projecttop0_.*
from
tecskill_topic projecttop0_
where
projecttop0_.pass_status=1
and projecttop0_.project_status=2
and to_date(projecttop0_.plan_start_date, ? )>?
以上是关于Spring Data Jpa Specification 调用Oracle 函数/方法的主要内容,如果未能解决你的问题,请参考以下文章
spring-data详解之spring-data-jpa:简单三步快速上手spring-data-jpa开发