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();

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

相关推荐
Jackson@ML1 小时前
用Visual Studio Code最新版开发C#应用程序
ide·vscode·c#
她说彩礼65万2 小时前
C# 代理模式
开发语言·c#·代理模式
张人玉5 小时前
TCP 的三次握手和四次挥手
网络·tcp/ip·c#
曹牧5 小时前
C#:三元运算符
开发语言·c#
m0_748248028 小时前
C++与C#布尔类型深度解析:从语言设计到跨平台互操作
c++·stm32·c#
bing.shao8 小时前
mongodb与redis在聊天场景中的选择
数据库·redis·mongodb
LeonDL1689 小时前
【通用视觉框架】基于C#+VisionPro开发的视觉框架软件,全套源码,开箱即用
人工智能·c#·visionpro·通用视觉框架·机器视觉框架·视觉框架软件·机器视觉软件
jyd012410 小时前
MongoDB 与 Java 实体类型 LocalTime 时区转换问题解决方案
java·数据库·mongodb
一抓掉一大把10 小时前
RuoYi .net-实现商城秒杀下单(redis,rabbitmq)
redis·mysql·c#·rabbitmq·.net
睡前要喝豆奶粉11 小时前
在.NET Core Web Api中使用阿里云OSS
阿里云·c#·.netcore