1

次のデータがあります。

/* 1 */
{
  "_id" : 1,
  "FirstName" : "John",
  "LastName" : "Doe",
  "Test" : [{
      "TestId" : ObjectId("5046109daedabb0cf8800f3f"),
      "DateTaken" : ISODate("2012-09-10T15:46:32.866Z")
    }, {
      "TestId" : ObjectId("506e0928aedabb087c4ec9d1"),
      "DateTaken" : ISODate("2011-06-26T18:05:52.625Z"),
      "Responses" : [{
          "AnswerId" : "506e0928aedabb087c4ec98c",
          "QuestionId" : ObjectId("506e0928aedabb087c4ec98b"),
          "ResponseDate" : ISODate("2011-06-26T04:00:00Z")
        }]
    }]
}

/* 2 */
{
  "_id" : 2,
  "FirstName" : "Jane",
  "LastName" : "Doe",
  "TestHistory" : [{
      "TestId" : ObjectId("506e0928aedabb087c4ec9d1"),
      "DateTaken" : ISODate("2011-06-26T18:05:52.625Z"),
      "Responses" : [{
          "AnswerId" : "506e0928aedabb087c4ec98c",
          "QuestionId" : ObjectId("506e0928aedabb087c4ec98b"),
          "ResponseDate" : ISODate("2011-06-26T04:00:00Z")
        }]
    }]
}

応答がない Test が存在するすべてのインスタンスを返すクエリを作成しようとしています。次のクエリを試しました。

  1. { "Test.Responses": { $exists: false } }
  2. { $and: [ { Test: { $exits: true } }, { "Test.Responses": { $exists: false} } ] }

どちらも 0 の結果を返します。私は何が欠けていますか?

4

1 に答える 1

1

あなたが探しているのはこれだと思います:

db.foo.find({
    Test: { $elemMatch: {
        Responses: { $exists: false }
    }
})

Testそれ以外の場合、クエリは下のすべてのドキュメントがプロパティを持たないレコードを探しResponsesます。

于 2013-03-05T19:33:54.387 に答える