2017-02-06 5 views
0

날짜 사이의 개체를 반환하는 쿼리를 작성하는 방법? 쿼리는 중첩 된 속성을 검색해야합니다. $gte$lte을 사용하지만 예상대로 작동하지 않는 것 같습니다. 두 날짜 사이에 history.startTime이있는 'task'객체를 반환하고 싶습니다.날짜 범위 쿼리 - 중첩 된 속성 간의 MongoDB

db.tasks.find({'history.startTime' : { '$gte': ISODate("2017-02-04T00:00:00.000Z"), '$lt': ISODate("2017-02-05T23:00:00.000Z")} }).pretty() 
    { 
      "_id" : ObjectId("588f53c5d00baa2558fd56ae"), 
      "desc" : "test3", 
      "category" : "Category1", 
      "project" : "Project1", 
      "_creator" : "582afb3800c1bc1f203edf39", 
      "history" : [ 
        { 
          "startTime" : ISODate("2017-02-06T11:49:42.570Z"), 
          "stopTime" : ISODate("2017-02-06T11:49:45.725Z"), 
          "_id" : ObjectId("589862d9449b4629f8dbaba7"), 
          "dt" : 3.155 
        }, 
        { 
          "startTime" : ISODate("2017-02-06T08:53:53.086Z"), 
          "stopTime" : ISODate("2017-02-06T11:47:58.098Z"), 
          "_id" : ObjectId("5898626e449b4629f8dbaba6"), 
          "dt" : 10445.012 
        }, 
        { 
          "startTime" : ISODate("2017-01-30T15:30:46.287Z"), 
          "stopTime" : ISODate("2017-01-30T15:32:52.979Z"), 
          "_id" : ObjectId("588f5c2cd00baa2558fd56b0"), 
          "dt" : 126.692 
        }, 
        { 
          "startTime" : ISODate("2017-01-30T13:55:09.738Z"), 
          "stopTime" : ISODate("2017-01-30T14:55:13.974Z"), 
          "_id" : ObjectId("588f53d1d00baa2558fd56af"), 
          "dt" : 3604.236 
        } 
      ], 
      "isCompleted" : false, 
      "isPerforming" : false, 
      "duration" : 14179.095000000001, 
      "updated" : ISODate("2017-02-06T11:49:45.725Z"), 
      "creationDate" : ISODate("2017-01-30T14:55:01.045Z"), 
      "__v" : 4 
    } 
+0

불가능합니다. 오직 수동으로하거나 $ unwind를 통해 집계 쿼리를 사용할 수 있습니다. –

답변

2

배열입니다. 검색어가 작동하지 않습니다. $ elemMatch를 사용해야합니다.

db.tasks.find({ 
    'history': { 
     $elemMatch: { 
      startTime: { 
       $gte: ISODate("2017-02-04T00:00:00.000Z"), 
       $lte: ISODate("2017-02-05T23:00:00.000Z") 
      } 
     } 
    } 
});