Projection of mongodb subdocument using C# .NET driver 2.0(用C#.NET驱动程序2.0实现MongoDB子文档的投影)
本文介绍了用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子文档的投影的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:用C#.NET驱动程序2.0实现MongoDB子文档的投影


基础教程推荐
猜你喜欢
- 全局 ASAX - 获取服务器名称 2022-01-01
- 错误“此流不支持搜索操作"在 C# 中 2022-01-01
- 首先创建代码,多对多,关联表中的附加字段 2022-01-01
- 是否可以在 asp classic 和 asp.net 之间共享会话状态 2022-01-01
- 从 VS 2017 .NET Core 项目的发布目录中排除文件 2022-01-01
- 经典 Asp 中的 ResolveUrl/Url.Content 等效项 2022-01-01
- 将事件 TextChanged 分配给表单中的所有文本框 2022-01-01
- 在 VS2010 中的 Post Build 事件中将 bin 文件复制到物 2022-01-01
- JSON.NET 中基于属性的类型解析 2022-01-01
- 如何动态获取文本框中datagridview列的总和 2022-01-01