c# - 从 2.0 MongoDb c# 驱动程序获取结果

我已经使用 1.0 和 2.0 c# 驱动程序为 MongoDb 构建了一个示例应用程序。

它们序列化相同的对象,我可以同时使用这两个对象进行写入并从 1.0.0 中读取。但我无法在 2.0 中使用 FindAsync 给我任何结果。

这是我的 1.0 查询,它返回一个文档:

var results = collection.AsQueryable<FlatCatalogItem>()
                        .FirstOrDefault(c => c.BatchId == "2015.01.27" 
                                            && c.Upcs.Any(u => u.UPC == "123456803"));

我的 2.0 查询使用与 FindAsync 相同的数据如下所示:

var task = collection.FindAsync(item => item.BatchId == "2015.01.27" 
                                     && item.Upcs.Any(u => u.UPC == "123456803"));
task.Wait();
var results = task.Result;

从 result 返回的 AsyncCursor 中没有任何内容。

results.MoveNextAsync().Wait(); // results.Current.Count = 0

这可能是我对 async 和 await 的无知,或者我可能错过了 2.0 find 方法的其他内容? 请注意,我不想使用 legacy 2.0 drivers

最佳答案

新的 API 是 async-only,你不应该阻止它。它不可扩展,可能会导致死锁。一直使用 async-await 或继续使用旧 API。在 async 方法中,查询应如下所示:

async Task Foo()
{
    FlatCatalogItem first = await collection.
        Find(c => c.BatchId == "2015.01.27" && c.Upcs.Any(u => u.UPC == "123456803")).
        FirstOrDefaultAsync();

    // use first
}

https://stackoverflow.com/questions/29417502/

相关文章:

mongodb - NoSQL 与关系数据库与可能的混合

java - Mongodb选择所有字段按一个字段分组并按另一个字段排序

javascript - 在 MongoDB 更新语句中使用变量

c# - 如何使用 c# 驱动程序删除 mongodb 文档中的嵌套数组元素

java - 在最新的 MongoDB java 驱动程序中使用 createIndex() 时,索

mongodb - 使用聚合框架按子文档字段分组

node.js - Mongoose - findByIdAndUpdate - 不适用于 req.

mongodb - 在 mongo shell 中加载和运行聚合

mongodb - Meteor.Collection 和 Meteor.Collection.Cu

ruby-on-rails - Mongoid 批量更新/Upsert 替代方案?