gpt4 book ai didi

c# - 如何使查询限制 1 linq C# MongoDB (ASP.NET MVC)

转载 作者:行者123 更新时间:2023-12-05 05:34:17 24 4
gpt4 key购买 nike

我想将数据从集合传递到 mongoDB 的 viewbag。如何进行查询(限制 1)以将结果分配给 viewbag 变量?

例如我想在 LINQ 中传递以下查询

db.getCollection('monitoreo').find({valor:'002'}).limit(1)

我保留返回整个列表的 Controller 示例,然后传递给 View

public ActionResult Index()
{
List<monitoreoModel> monitoreo = monitoreoCollection.AsQueryable<monitoreoModel>().ToList();
return View(monitoreo);
}

请帮忙,谢谢!

最佳答案

如果你想使用Linq,你可以按照下面的例子:

var result = monitoreoCollection
.AsQueryable()
.Where(x => x.Valor == "002")
.Take(1) // This is not required, but asserts that MongoDB returns only one document
.FirstOrDefault()

以上代码仅返回第一个匹配项,如果不存在则返回 null。

如果您想使用简单的查找命令而不是聚合管道,您可以使用以下命令。 Limit 仅在 Find 命令的 async 版本中受支持,因此您必须将操作更改为 async :

public async Task<ActionResult> Index()
{
var result = await (await monitoreoCollection.FindAsync(
x => x.Valor == "002",
new FindOptions<EventBase, EventBase>() { Limit = 1 }))
.FirstOrDefaultAsync();
return View(result);
}

关于c# - 如何使查询限制 1 linq C# MongoDB (ASP.NET MVC),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73655710/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com