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

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

相关推荐
范纹杉想快点毕业8 小时前
从单片机基础到程序框架:构建嵌入式系统的完整路径
数据库·mongodb
bugcome_com9 小时前
阿里云 OSS C# SDK 使用实践与参数详解
阿里云·c#
范纹杉想快点毕业10 小时前
从单片机基础到程序框架:全方位技术深度解析
数据库·mongodb
懒人咖19 小时前
缺料分析时携带用料清单的二开字段
c#·金蝶云星空
bugcome_com20 小时前
深入了解 C# 编程环境及其开发工具
c#
wfserial1 天前
c#使用微软自带speech选择男声仍然是女声的一种原因
microsoft·c#·speech
space62123271 天前
在SpringBoot项目中集成MongoDB
spring boot·后端·mongodb
阔皮大师1 天前
INote轻量文本编辑器
java·javascript·python·c#
kylezhao20191 天前
C# 中的 SOLID 五大设计原则
开发语言·c#
全栈前端老曹1 天前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈