the*_*ino 5 java date mongodb mongodb-query
(我知道我刚问了一个关于这个的问题,但答案引导我提出这个问题,我认为创建另一个问题是合适的)
我在MongoDB中有一个如下所示的对象:
{
"id" : NumberLong(12345),
"dateModified" : ISODate("2015-01-21T19:43:17.440Z")
}
Run Code Online (Sandbox Code Playgroud)
我需要创建的用于检索它的查询应该如下所示(对象中的日期介于这两个日期之间):
db.history.find({"dateModified" : { "$gte" : ISODate("2015-01-19T00:00:00.000Z") , "$lte" : ISODate("2015-01-25T00:00:00.000Z")}});
Run Code Online (Sandbox Code Playgroud)
不幸的是,我正在使用Java,事情变得有趣.这是我的Java查询:
java.util.Date fromDate;
java.util.Date toDate;
BasicDBObject searchQuery = new BasicDBObject();
searchQuery.put("dateModified", BasicDBObjectBuilder.start("$gte", fromDate).add("$lte", toDate).get());
Run Code Online (Sandbox Code Playgroud)
几乎我到网上的每个地方都建议我使用上面的Java代码来执行此查询,但此查询的文本输出是:
{"dateModified" : { "$gte" : { "$date" : "2015-01-19T00:00:00.000Z"} , "$lte" : { "$date" : "2015-01-25T00:00:00.000Z"}}
Run Code Online (Sandbox Code Playgroud)
此查询不返回任何结果,因为它不以ISODate格式查询.编辑:我的意思是,如果我在mongo shell中使用上述查询,我得不到任何结果,但如果我使用我发布的第一个查询,我会得到结果.
我的问题是为什么这不会像所有人都说的那样自动转换为ISODate?或者,我该怎么做才能确保此查询转换为ISODate格式?
如果您实际上从 Java 运行该查询,它将起作用。但将文本输出粘贴到 shell 中则不会,因为 BSON 文档的 Java 驱动程序的文本输出格式是MongoDB Extended JSON ,与mongoexport等工具使用的格式相同。然而,shell 无法理解这种格式。存在一个Jira 问题,请求 shell 支持扩展 JSON。
| 归档时间: |
|
| 查看次数: |
4545 次 |
| 最近记录: |