首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MongoDB从$in语句返回第一个匹配项

MongoDB从$in语句返回第一个匹配项
EN

Stack Overflow用户
提问于 2015-05-28 01:03:40
回答 1查看 533关注 0票数 2

我有一个MongoDB查询,比如;

代码语言:javascript
运行
复制
db.Mappings.find({
            "UrlHash" : {
                "$in" : [ 
                    "F0B457493DDE7C53860BB770193848AD", 
                    "0A096439E718BFB7AE77C65B38AA904E", 
                    "8DC5195910E952C181BAF535ACDD2F35"
                ]
            },
            "TopicId" : "3511"
        })

实际上,我想要做的是,从收集中获取第一个匹配$in语句的结果。由于我不能做到这一点,我正在发送所有的可能性在一个镜头,得到名单,并获得第一个结果。

因此,我想要做的是,如果查询与F0B457493DDE7C53860BB770193848AD匹配,则首先获取它并停止,否则从0A096439E718BFB7AE77C65B38AA904E获取第一个结果,依此类推。

我知道我可以进行单独的查询和迭代,直到找到为止,但我只是想知道是否有一种聪明的方法可以一次完成。

这样做有可能吗?

EN

回答 1

Stack Overflow用户

发布于 2019-10-31 07:48:05

这不能准确地回答您的问题,但保留了列表中的顺序。这样你就可以得到结果中的第一个元素作为你的答案。请参阅其他说明here

代码语言:javascript
运行
复制
    let keys = [
      "F0B457493DDE7C53860BB770193848AD", 
      "0A096439E718BFB7AE77C65B38AA904E", 
      "8DC5195910E952C181BAF535ACDD2F35"
    ]

​    let match = { $match : { UrlHash : { $in : order }, TopicId : "3511" } };

    let addFields = { $addFields : { __order : { $indexOfArray : [ keys, "$UrlHash" ] } } };

    let sort = { $sort : { __order : 1 } };

    db.Mappings.aggregate( [ match, addFields, sort ] );
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30488885

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档