我需要使用querydsl between查询,仅用于没有时间戳的日期比较。
QueryDsl:
Date startDate=
Date endDate=
QEmp qEmp=
BooleanExpression empExp = qEmp.id.dob.between(startDate, endDate);表:
select dob from employee where eid=2;
10-MAR-07 12.00.00.000000000 AM道布之间的SQL查询:
select * from employee where dob between trunc(start date) and trunc(end dat)这将查找不带时间戳的开始日期和结束日期之间的记录。我需要在QueryDSl中执行相同的操作。数据库为Oracle。
发布于 2020-06-05 01:13:16
不幸的是,DATE_TRUNC不是在JPQL中定义的函数,因此,没有一个JPA实现--比如Hibernate --支持这个函数。
但是,DATE_TRUNC可以注册为各种JPA实现中的自定义函数,然后您可以使用一组自定义的QueryDSL Templates来包含对这些函数的处理。
例如,对于Hibernate:
public class DateTruncMetadataBuilderInitializer
implements MetadataBuilderInitializer {
@Override
public void contribute(MetadataBuilder metadataBuilder,
StandardServiceRegistry serviceRegistry) {
metadataBuilder.applySqlFunction("DATE_TRUNC",
new SQLFunctionTemplate(DateType.INSTANCE,
"DATE_TRUNC(?1, ?2)"));
}
}然后,您需要在名为META-INF/services/org.hibernate.boot.spi.MetadataBuilderInitializer的JAR资源文件中注册该类。
进行此更改后,您可以在JPQL/HQL查询中使用DATE_TRUNC,如下所示:
SELECT a FROM Entity a
WHERE a.dateField BETWEEN DATE_TRUNC('day', :start) AND DATE_TRUNC('day', :end)现在,您必须使此函数对QueryDSL可用。您可以通过声明一个自定义模板来完成此操作:
public class MyTemplates extends JPQLTemplates {
public MyTemplates() {
add(DateTimeOps.TRUNC_DAY, "DATE_TRUNC('day', {0})");
}
}然后按如下方式使用它:
new JPAQuery(entityManager, new MyTemplates()).from(entity)
.select(Expressions.dateOperation(DateTimeOps.TRUNC_HOUR, dateExpression))然而,由于Spring集成在中间,我认为Templates更难绑定到查询。
或者,您可以研究一下blaze-persistence-querydsl扩展,它对JPQL中的日期/时间操作提供了开箱即用的支持。
https://stackoverflow.com/questions/51762431
复制相似问题