1

假设我在 MongoDB 集合上有以下文档结构:

{
  "Applications" : [{
      "JoinDate" : new Date("10/2/2013 18:06:30"),
      "Key" : "shtube",
      "Roles" : ["Administrator", "Moderator"]
    }],
  "Comment" : "Cool",
  "ConfirmationKey" : "981c69fe-6fff-47d6-bb82-3b5f1deeef25",
  "CreationDate" : new Date("8/2/2013 17:43:42"),
  ...
} 

如何使用 MongoCursor 中的SetFields()方法仅检索“角色”字段(针对性能问题)?此时我只知道检索子文档并访问“角色”。但我不需要整个子文档信息。

4

1 回答 1

2

您可以使用投影来使用点表示法(使用外壳)仅提取您想要的字段:

db.myCollection.find({ "Applications.Roles" : { $exists: true } },
             {  "Applications.Roles" : 1 })

在上面的示例中,它只是返回包含 Applications.Roles 结构的文档。

您可以在此处阅读有关预测的更多信息。

仅供参考:您不能有效地使用 LINQ 从 C# 进行投影。它在客户端本地进行投影。

另一种选择是使用 $elemMatch (但是,在这种情况下,如果您不进行特定查询,它可能不适合您的需求)。

于 2013-02-10T23:02:50.093 回答