繁体   English   中英

如何在 C# 的 MongoDB 驱动程序中获取数组中一个字段的值

[英]How to get values of one field in array in MongoDB Driver for C#

我有课程:

public class Whole
{
  public ObjectId Id { get; set; }
  public string NeededField { get; set; }
  public List<Detail> Details { get; set; }
  public string SomeUnnecesaryField { get; set; } 
}

public class Detail
{
  public string NeededField { get; set; }
  public string NotNeededField { get; set; }
}

[BsonNoId]
[BsonIgnoreExtraElements]
public class MyNeededInformations
{
  public string NeededField { get; set; }
  [BsonElement("Details.NeededField")]
  public List<string> DetailsNeededFields { get; set; }
}

我试图通过投影来获得它:

var filter = someFilter;
var projection = Builders<Whole>.Projection
  .Include(w => w.NeededField)
  .Include(w => w.Details)
  .Exclude("_id");
return Collection
  .Find(filter)
  .Project(projection)
  .As<MyNeededInformations>()
  .ToList();

而且我每次都会收到DetailsNeededFields作为空列表。 我想要像标准聚合一样的字符串列表:

db.collection.aggregate([
  {$match: someFilter},
  {$project: {"_id": 0, "NeededField": 1, "DetailsNeededFields": "$Details.NeededField"}}
])

可以使用AsQueryable接口轻松实现,如下所示:

var results = await collection
    .AsQueryable()
    .Where(_ => true)
    .Select(w => new MyNeededInformations
    {
        NeededField = w.NeededField,
        DetailsNeededFields = (List<string>)w.Details.Select(d => d.NeededField)
    })
    .ToListAsync();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM