C# 操作mongodb 多次查询快还是使用管道查询速度快

最近特殊原因,需要查询表数据,分别两张表,结构大概如下:

cs 复制代码
 public partial class ItemRelationPO : DbExtField
 {
     /// <summary>
     /// 道具ID 唯一
     /// </summary>
     [BsonId]
     [BsonElement("ItemOid")]
     public ulong ItemOid { get; set; }

     /// <summary>
     /// 父节点
     /// </summary>
     public ulong Parent { get; set; }

     /// <summary>
     /// 所有者ID
     /// </summary>
     public ulong Owner { get; set; }

     /// <summary>
     /// 关联字段
     /// </summary>
     public ulong Associated { get; set; }

     /// <summary>
     /// 祖先节点
     /// </summary>
    // public string AncestorsStr { get; set; }
 }
 
 
 public partial class GameItemPO : DbExtField
{
    /// <summary>
    /// 组件ID
    /// </summary>
    [BsonId]
    [BsonElement("ItemOid")]
    public ulong ItemOid { get; set; }

    /// <summary>
    /// 模板ID
    /// </summary>
    public long TemplateId { get; set; }

    /// <summary>
    /// 数量
    /// </summary>
    public long Count { get; set; }

    /// <summary>
    /// NFT 信息
    /// </summary>
    public NftInfoPO NftInfo { get; set; }

    /// <summary>
    /// 是否是容器
    /// </summary>
    public bool IsContainer { get; set; }

    /// <summary>
    /// 容器容量
    /// </summary>
    public long Capacity { get; set; }

    /// <summary>
    /// CD 信息
    /// </summary>
    public ItemCDlInfoPO CdInfo { get; set; }

    /// <summary>
    /// 道具失效时间----
    /// </summary>
    [BsonRepresentation(BsonType.String)]
    public DateTimeOffset ExpireEndTime { get; set; } = DateTimeOffset.MinValue;

}

两张表数据大概在1000W,我需要查询两张表数据,

方式1:分别两次查询,然后拼接

cs 复制代码
Stopwatch stopwatch = Stopwatch.StartNew();
var relationFilter = Builders<ItemRelationPO>.Filter.In(a => a.Owner, playerIds);
var data = await ItemRelationDb.Find(relationFilter).ToListAsync();
var ids = data.Select(a => a.ItemOid).ToList();

var filter = Builders<GameItemPO>.Filter.In(o => o.ItemOid, ids);
var listItems = await GameItemDb.Find(filter).ToListAsync();
//拼接成大类
var result = ItemRepositoryUtility.ConvertPOToDomain(listItems, _mapper, data);
stopwatch.Stop();
_logger.LogInformation("原始查询:{ml}", stopwatch.ElapsedMilliseconds);

方式2:使用管道查询

cs 复制代码
stopwatch.Restart();
var playerIdsBson = playerIds.Select(id => new BsonInt64((long)id)).ToList();
_logger.LogInformation("Player IDs Bson: " + string.Join(", ", playerIdsBson));
var relationFilter2 = Builders<ItemRelationPO>.Filter.In(a => (long)a.Owner, playerIdsBson);

_logger.LogInformation("Filter: " + relationFilter2.ToBsonDocument().ToJson());
var filterBson = new BsonDocument
{
    { "Owner", new BsonDocument { { "$in", new BsonArray(playerIdsBson) } } }
};
var pipeline = new BsonDocument[]
    {
        new("$match", filterBson),
        new ("$lookup",new BsonDocument{
            { "from", GameItemDb.CollectionNamespace.CollectionName },
            { "localField", "_id" },
            { "foreignField", "_id" },
            { "as", "gameItems" }

        }),
        new("$unwind", "$gameItems"),
        new BsonDocument("$project", new BsonDocument
            {
                { "_id", 0 },
                { "ItemOid", 1 },
                { "Parent", 1 },
                { "Owner", 1 },
                { "Associated", 1 },
                //{"item","$gameItems" }
                { "TemplateId", "$gameItems.TemplateId" },
                { "Count", "$gameItems.Count" },
                { "NftInfo", "$gameItems.NftInfo" },
               // { "Types","$gameItems._t"}
            })

    };

var result2 = await ItemRelationDb.Aggregate<GameItem>(pipeline)
      .ToListAsync();

测试结果:发现,两次访问所需时间比使用管道查询性能要高

相关推荐
爬山算法13 小时前
MongoDB(113)如何使用第三方工具进行MongoDB监控?
数据库·mongodb
宝桥南山15 小时前
GitHub Models - 尝试一下使用GitHub Models
microsoft·ai·微软·c#·github·.netcore
hixiong12318 小时前
C# OpenvinoSharp部署INSID3
开发语言·人工智能·ai·c#·openvinosharp
星辰徐哥19 小时前
Unity C#入门:变量的定义与访问权限(public/private)
unity·c#·lucene
leoufung19 小时前
LeetCode 30:Substring with Concatenation of All Words 题解(含 C 语言 uthash 实现)
c语言·leetcode·c#
hacker70719 小时前
Visual Studio安装教程(C#开发版)
ide·c#·visual studio
SKY -dada19 小时前
Understand 使用教程
开发语言·c#·流程图·软件构建·敏捷流程·代码复审·源代码管理
xingpanvip20 小时前
星盘接口开发文档:日运语料接口指南
android·开发语言·前端·css·php·lua
William_cl1 天前
【C#/.NET 进阶】ASP.NET 架构与最佳实践:DI 依赖注入(IoC 核心)从入门到避坑
c#·asp.net·.net
武藤一雄1 天前
WPF:MessageBox系统消息框
前端·microsoft·c#·.net·wpf