使用Java驱动程序运行准备好的mongodb查询

时间:2017-01-23 17:20:58

标签: java mongodb

我无法格式化下面的查询,因为它可以通过MongoDB Java driver提供的JSON实用程序进行解析,并且我喜欢建议。首先,一些背景。

测试框架在每次运行结束时将测试结果存储在MongoDB中。 以下是来自集合' TestResults'

的2个此类样本
{
        "_id" : ObjectId("SomeId#1"),
        "_class" : "com.example.dao.entity.TestResults",
        "testScenario" : "Test login",
        "runId" : 314,
        "runDate" : ISODate("2016-12-14T15:51:04.586Z"),
        "status" : "passed"
}

{
        "_id" : ObjectId("SomeId#2"),
        "_class" : "com.example.dao.entity.TestResults",
        "testScenario" : "Test reset password",
        "runId" : 314,
        "runDate" : ISODate("2016-12-14T20:50:01.269Z"),
        "status" : "passed"
}

另一个名为“Queries'包含预先编写的查询模板。 find下的runDate文档下面的查询:

{
        "_id": ObjectId("SomeId#3"),
        "_class": "com.example.dao.entity.Query",
        "query": "{\"runDate\":{\"$gte\":new Date(\"%1$s\"),\"$lt\":new Date(\"%2$s\")}}"
}

目的是在添加有效时间范围后,使用上述查询模板对上述' testResults'进一步收集和处理。这是我到目前为止所尝试的内容:

使用JSON.parse()

LocalDateTime dateTime1=LocalDateTime.of(2016, 12, 14, 00, 00,00);
LocalDateTime dateTime2 = dateTime1.plusHours(24);

/* Gets date range query from  'Queries' collection */
String dateRange = getDateRangeQuery(); 
/* Apply time range for last 24 hours... */
dateRange = String.format(dateRange,dateTime1.format(DateTimeFormatter.ISO_DATE_TIME),dateTime2.format(DateTimeFormatter.ISO_DATE_TIME));

BasicDBObject dayQuery=(BasicDBObject) JSON.parse(dateRange);
FindIterable<Document> result = database.getCollection("testResults").find(dayQuery);
result.forEach(new Block<Document>() {

    @Override
    public void apply(Document t) {
        System.out.println("QUERY RESULT:"+t.toJson());

    }
});

运行时,JSON.parse()会抛出此异常

 com.mongodb.util.JSONParseException: 
{"runDate":{"$gte":new Date("2016-12-14T00:00:00"),"$lt":new Date("2016-12-15T00:00:00")}}
           ^    
at com.mongodb.util.JSONParser.read(JSON.java:301)
at com.mongodb.util.JSONParser.parse(JSON.java:172)
at com.mongodb.util.JSONParser.parseObject(JSON.java:263)
at com.mongodb.util.JSONParser.parse(JSON.java:227)
at com.mongodb.util.JSONParser.parseObject(JSON.java:263)
at com.mongodb.util.JSONParser.parse(JSON.java:227)
at com.mongodb.util.JSONParser.parse(JSON.java:155)
at com.mongodb.util.JSON.parse(JSON.java:92)
at com.mongodb.util.JSON.parse(JSON.java:73)

使用BsonDocument.parse()

BsonDocument.parse()能够解析查询,但我无法找到一种方法来配置BsonDocument的集合名称,然后在MongoDatabase.runCommand()中使用

那么现在有什么选择呢?

2 个答案:

答案 0 :(得分:1)

您需要将查询模板更新为兼容的JSON类型,以便对其进行解析。

查询模板Json:

{
    "_id": ObjectId("SomeId#3"),
    "_class": "com.example.dao.entity.Query",
    "query": "{"runDate":{ "$gte" :{"date" : { "$date" : "%1$s"}}}}"
}

代码:

Instant dateTime = Instant.now();
String dateRange = String.format(getDateRangeQuery(),dateTime.toString()));

现在,您可以在JSON.parse()之后将其作为常规查询运行。

更多关于其他类型的信息:

https://docs.mongodb.com/manual/reference/mongodb-extended-json/

答案 1 :(得分:0)

查询中似乎不支持新的Date语法,但仅限于内部Javascript库。

对于查询,请替换&#34; new Date&#34;用&#34; ISODate&#34; (例如ISODate(&#34; 2017-01-10T10:13:58.630Z&#34;))它应该有效。