使用QueryDSLMongodb获取从开始日期到结束日期的所有行

问题描述

我有这个queryDSL查询

    QReport report = QReport.report;
    BooleanBuilder builder = new BooleanBuilder();

    if (startDate != null) {
        builder.and(report.modificationDate.after(startDate));
    }

    if (endDate != null) {
        builder.and(report.modificationDate.before(endDate));
    }

但是,如果我要查找从 09/04/2018 09/04/2018 的行,则行不通。 或从 09/04/2018 2018/05/05 -仅找到 2018/04/09 行。

我可以在endDate添加 23.59.59 时间,但是查询DSL中是否可以为此提供一些选择?

例如-获取从开始日期到结束日期的所有行

解决方法

TemporalExpression是QueryDSl中的LiteralExpression的{​​{1}}。 ComparableExpression只是TemporalExpression#before的替代(小于)。 ComparableExpression#lt也有ComparableExpression(表示小于等于)。

因此您可以将代码更改为loe(...)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...