gpt4 book ai didi

c# - 如何从 C# 中为 MongoQuery 计时

转载 作者:可可西里 更新时间:2023-11-01 10:01:31 26 4
gpt4 key购买 nike

我尝试在 C# 中对具有索引的列计时 Mongo 查询:

DateTime startTime = DateTime.Now;
MongoCollection<BsonDocument> voteCol = database.GetCollection<BsonDocument>("XXX");
var query = new QueryDocument("YYY", "23915");
MongoCursor<BsonDocument> cursor = voteCol.Find(query).SetSortOrder(SortBy.Descending("ZZZ")).SetLimit(10).SetSkip(20);
TimeSpan elapsedTime = DateTime.Now - startTime;
Console.WriteLine("Elapsed: {0}, in seconds: {1}, in milliseconds: {2} ",
elapsedTime, elapsedTime.TotalSeconds, elapsedTime.TotalMilliseconds, cursor.Count());

每次它等于 0 时我都会得到结果。这是否意味着速度太快或我错过了什么?

最佳答案

这是因为你实际上没有从 mongodb 加载数据。当您开始遍历 MongoCursor 时,将加载数据。您可以轻松使用 ToList 方法从数据库加载数据:

var data = voteCol.Find(query)
.SetSortOrder(SortBy.Descending("ZZZ"))
.SetLimit(10)
.SetSkip(20)
.ToList();

另外我建议使用 Stopwatch评估耗时。

关于c# - 如何从 C# 中为 MongoQuery 计时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7144789/

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