4

这方面似乎缺少 mongoDB API 文档。我正在尝试使用聚合函数来获取某个集合中流行标签的计数。这是我希望执行的命令:

db.runCommand(
       { aggregate : "articles", 
         pipeline : [ { $unwind : "$Tags" }, 
                      { $group : { _id : "$Tags", count : { $sum : 1 } }
                      } ]});

当我使用 shell 执行此操作时,我得到以下信息:

{
    "result": [{
        "_id": "2012",
        "count": 3
    }, {
        "_id": "seattle",
        "count": 5
    }],
    "ok": 1
}

我正在使用 c# 4.0,所以我想我更愿意将它作为一个动态对象取回,但我会尽我所能......

FWIW,我正在使用 mongoDB for Windows,32 位,v2.1.1(每晚)

4

2 回答 2

5

这是相应的 C# 驱动程序文档页面:RunCommand()。所以基本上你打电话Database.RunCommand("MyCommand")。对于需要(多个)属性的更复杂命令的示例,JIRA 中的这张票可能会派上用场:CSHARP-478

于 2012-06-06T06:51:49.630 回答
1

在 MongoDB CSharp Drivers 2.0.0+ 中:
我使用以下语法来运行此类命令:

var command = new CommandDocument
{
    {"aggregate", "TestCollection"},
    {
        "pipeline", new BsonArray
        {
            new BsonDocument {{"$unwind", "$Tags"}},
            new BsonDocument
            {
                {
                    "$group", new BsonDocument
                    {
                        {"_id", "$Tags"},
                        {"count", new BsonDocument {{"$sum", 1}}}
                    }
                }
            }
        }
    }
};

var result = db.RunCommand<BsonDocument>(command)["result"]
    .AsBsonArray.ToList();
于 2016-12-21T12:53:17.333 回答