用C#.NET驱动程序2.0实现MongoDB子文档的投影 [英] Projection of mongodb subdocument using C# .NET driver 2.0

查看:0
本文介绍了用C#.NET驱动程序2.0实现MongoDB子文档的投影的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有以下结构:

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,就像您为Find所做的那样,驱动程序可以使其中一些内容消失。例如,我认为以下内容应该适用于您:

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

这应该只为每个类别返回一个字符串的可枚举值(tasks.name)。驱动程序将检查此投影,并且仅拉回tasks.name字段。

这篇关于用C#.NET驱动程序2.0实现MongoDB子文档的投影的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆