我正在使用 MongoDB 2.2.3 的官方 C# 驱动程序
如何使用 C# 驱动程序设置光标的批量大小?
使用 javascript,我可以创建一个光标并为其设置批量大小:
var cursor = db.statistics.find(query).batchSize(100)
我可以使用以下语句迭代所有项目:
while(cursor.objsLeftInBatch()>0){
var doc = cursor.next();
//process doc
}
我希望在 C# 中具有相同的行为并支持 async/await。
我知道我可以使用 C# 中的游标,但它的默认批量大小是 4MB。
这太匹配了,无法通过一次调用返回给客户端。
您可以在中设置批量大小FindOptions
的参数FindAsync
.
这是显式处理批次的基本模式:
var filter = new BsonDocument();
var options = new FindOptions<BsonDocument>
{
// Get 100 docs at a time
BatchSize = 100
};
using (var cursor = await test.FindAsync(filter, options))
{
// Move to the next batch of docs
while (await cursor.MoveNextAsync())
{
var batch = cursor.Current;
foreach (var doc in batch)
{
// process doc
}
}
}
但你也可以打电话ForEachAsync
光标上的批次将根据需要透明地获取:
using (var cursor = await test.FindAsync(filter, options))
{
await cursor.ForEachAsync(doc =>
{
// process doc
});
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)