使用 C# .NET 驱动程序 2.0 投影 mongodb 子文档

2024-02-21

我有以下结构:

public class Category
{
    [BsonElement("name")]
    public string CategoryName { get; set; }

    [BsonDateTimeOptions]
    [BsonElement("dateCreated")]
    public DateTime DateStamp { get; set; }

    [BsonElement("tasks")]        
    public List<TaskTracker.Task> Task { get; set; }
}

public class Task
{
    [BsonElement("name")]
    public string TaskName { get; set; }

    [BsonElement("body")]
    public string TaskBody { get; set; }
}

我正在尝试查询Category得到所有的TaskName值,然后将它们返回到要在列表框中显示的列表。

我尝试过使用这个查询:

var getTasks = Categories.Find<Category>(x => x.CategoryName == catName)
                         .Project(Builders<Category>.Projection
                                                    .Include("tasks.name")
                                                    .Exclude("_id"))
                         .ToListAsync()
                         .Result;   

但返回的是:{"tasks": [{"name: "test"}]}.

有没有办法只返回字符串值?


正如 Avish 所说,您必须使用聚合 API 才能使生成的文档看起来像您想要的那样。但是,如果您像对“查找”所做的那样使用项目的表达式树 API,则驱动程序可以使其中一些问题消失。例如,我相信以下内容应该适合您:

var taskNames = await Categores.Find(x => x.CategoryName == catName)
    .Project(x => x.Tasks.Select(y => y.Name))
    .ToListAsync();

这应该只是带回一个可枚举的字符串(tasks.name)对于每个类别。驾驶员将检查该投影并仅拉回tasks.name field.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 C# .NET 驱动程序 2.0 投影 mongodb 子文档 的相关文章