MongoDB C# 如何通过多个不同的字段过滤文档?
MongoDB C# how to filter documents by multiple distinct fields?
我在 MongoDB 中有一份公司股票价格列表。每个文档如下所示:
{
"_id":"5b93f2719c02f096d5cb9608",
"dateString":"2018-09-07",
"close":260.87,
"companyName":"Adobe Systems, Inc.",
"high":263.67,
"low":257.12,
"open":258,
"symbol":"ADBE",
"timestamp":1536296400
}
数据库中当然有很多这样的文档。
我需要以不同的方式获取符号和公司名称列表,例如我想要这个:
List<BsonDocument> {
{ "symbol": "ADBE", "companyName": "Adobe Systems, Inc." },
{ "symbol": "MCO", "companyName": "Moody's Corp" }
...
}
我找到了一种只为一个字段获取不同值的方法,如下所示:
public List<string> GetCompanySymbolNames() {
return m_CompanyCollection.Distinct<string>("symbol", new BsonDocument())?.ToList();
}
但是有没有办法通过 2 个字段进行不同的过滤?
这是一个 C# mongodb 驱动程序
p.s。我看过这个话题
但我无法让它与 C# 驱动程序一起工作
我是这样解决的:
public List<SymbolItem> GetCompanySymbolItems() {
// https://docs.mongodb.com/manual/reference/operator/aggregation/group/
var result = new List<SymbolItem>();
m_CompanyCollection.Aggregate()
.Group(new BsonDocument("_id",
new BsonDocument {{"symbol", "$symbol"}, {"companyName", "$companyName"}}))
.ToList()
.ForEach(bson => {
var symbolData = bson["_id"];
result.Add(new SymbolItem {
Tag = symbolData["symbol"].AsString,
Name = symbolData["companyName"].AsString
});
});
return result;
}
现在我得到了我想要的结果
db.col.aggregate([{
"$group": {
"_id": {
"symbol": "$symbol",
"companyName": "$companyName"
},
"occurrences": {
"$sum": 1
}
}
},
{
"$project": {
"symbol": "$_id.symbol",
"companyName": "$_id.companyName",
"occurrences": "$occurrences",
"_id": 0
}
}
])
也许你可以使用聚合函数:
例如,我的 collection:
代码:
var dist = dbCollection.Aggregate().Group(d => d.Name, o =>
new
{
Name = o.Key,
Data = o.Select(_ => _.Symbol).Distinct(),
}).ToEnumerable();
dist.ToList().ForEach(_ =>
{
_.Data.ToList().ForEach(d => Console.WriteLine("Company: " +_.Name + " Symbol: " + d));
}
);
结果:
我在 MongoDB 中有一份公司股票价格列表。每个文档如下所示:
{
"_id":"5b93f2719c02f096d5cb9608",
"dateString":"2018-09-07",
"close":260.87,
"companyName":"Adobe Systems, Inc.",
"high":263.67,
"low":257.12,
"open":258,
"symbol":"ADBE",
"timestamp":1536296400
}
数据库中当然有很多这样的文档。 我需要以不同的方式获取符号和公司名称列表,例如我想要这个:
List<BsonDocument> {
{ "symbol": "ADBE", "companyName": "Adobe Systems, Inc." },
{ "symbol": "MCO", "companyName": "Moody's Corp" }
...
}
我找到了一种只为一个字段获取不同值的方法,如下所示:
public List<string> GetCompanySymbolNames() {
return m_CompanyCollection.Distinct<string>("symbol", new BsonDocument())?.ToList();
}
但是有没有办法通过 2 个字段进行不同的过滤? 这是一个 C# mongodb 驱动程序
p.s。我看过这个话题
我是这样解决的:
public List<SymbolItem> GetCompanySymbolItems() {
// https://docs.mongodb.com/manual/reference/operator/aggregation/group/
var result = new List<SymbolItem>();
m_CompanyCollection.Aggregate()
.Group(new BsonDocument("_id",
new BsonDocument {{"symbol", "$symbol"}, {"companyName", "$companyName"}}))
.ToList()
.ForEach(bson => {
var symbolData = bson["_id"];
result.Add(new SymbolItem {
Tag = symbolData["symbol"].AsString,
Name = symbolData["companyName"].AsString
});
});
return result;
}
现在我得到了我想要的结果
db.col.aggregate([{
"$group": {
"_id": {
"symbol": "$symbol",
"companyName": "$companyName"
},
"occurrences": {
"$sum": 1
}
}
},
{
"$project": {
"symbol": "$_id.symbol",
"companyName": "$_id.companyName",
"occurrences": "$occurrences",
"_id": 0
}
}
])
也许你可以使用聚合函数:
例如,我的 collection:
代码:
var dist = dbCollection.Aggregate().Group(d => d.Name, o =>
new
{
Name = o.Key,
Data = o.Select(_ => _.Symbol).Distinct(),
}).ToEnumerable();
dist.ToList().ForEach(_ =>
{
_.Data.ToList().ForEach(d => Console.WriteLine("Company: " +_.Name + " Symbol: " + d));
}
);
结果: