gpt4 book ai didi

c# - 在所有集合中查找字段的最大值

转载 作者:太空宇宙 更新时间:2023-11-03 21:06:24 26 4
gpt4 key购买 nike

我有一个包含集合的数据库,这些集合包含表单上的文档:

{ "_id" : 4, "value" : 2 }

我想以一种有效的方式在所有集合中找到最大的 "_id"。目前,我有一个工作方法:

public long getLastTimestamp()
{
var tempList = getChannelNames();
var channelList = new List<IMongoCollection<BsonDocument>>();
var docuList = new List<BsonDocument>();

foreach (var channel in tempList)
{
channelList.Add(_database.GetCollection<BsonDocument>(channel.name));
}

foreach (var channel in channelList)
{
var filter = Builders<BsonDocument>.Filter.Exists("_id");
var result = channel.FindAsync(filter).Result.ToList();

foreach (var docu in result)
{
docuList.Add(docu);
}
}

var timeList = new List<long>();

foreach (var docu in docuList)
{
Console.WriteLine(docu);
if (!docu["_id"].IsObjectId)
timeList.Add(docu["_id"].ToInt64());
}

return timeList.Max();
}

它有效,但我认为它不是很有效率。有没有人有一些意见或建议?

编辑:我最终这样做了:

    public long getLastTimestamp()
{
var filter = Builders<BsonDocument>.Filter.Exists("value");
return getChannelNames()
.Select(channel => _database.GetCollection<BsonDocument>(channel.name))
.SelectMany(channel => channel.FindAsync(filter).Result.ToList())
.Max(docu => docu["_id"].ToInt64());
}

最佳答案

检查一下:

public long getLastTimestamp()
{
//var tempList = getChannelNames();
var channelList = new List<IMongoCollection<BsonDocument>>();
var docuList = new List<BsonDocument>();

foreach (var channel in getChannelNames())
{
var filter = Builders<BsonDocument>.Filter.Exists("_id");
var result = _database.GetCollection<BsonDocument>(channel.name)
.FindAsync(filter).Result.ToList();

return result.Where(x => !x["_id"].IsObjectId)
.Max(entry => entry["_id"].ToInt64);
}

return 0;
}

无法测试它,因为我无法使用这些对象。在 linq 部分,您可能必须转换为列表或数组才能获得可用的 Where()Max()

再次存储和迭代总是比较慢。

public long getLastTimestamp()
{
var filter = Builders<BsonDocument>.Filter.Exists("_id");

return getChannelNames()
.Select(channel => _database.GetCollection<BsonDocument>(channel.name).FindAsync(filter).Result.ToList())
.Where(doc => !doc["_id"].IsObjectId)
.Max(doc => doc["_id"].ToInt64);
}

关于c# - 在所有集合中查找字段的最大值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40869580/

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