如何解决使用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(...)
。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。