首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >查询嵌套文档中的字段“作为数组”

查询嵌套文档中的字段“作为数组”
EN

Stack Overflow用户
提问于 2019-08-07 23:38:00
回答 2查看 50关注 0票数 0

我有一个数据库,它具有这样的结构:

{
    "_id" : ObjectId("x"),
    "T_K" : 750,
    "P_Pa" : 2026500,
    "phi" : 1,
    "composition" : [
        {
            "species" : "NC10H22",
            "mol_fraction" : 0
        },
        {
            "species" : "NC12H26",
            "mol_fraction" : 1
        }
    ],

我的目标是找到具有特定组成的对象(由字段“mol_fraction”给出),假设是0,1。但如果我尝试以下命令:

db.prova.find({"composition.mol_fraction":[0,1]})

它什么也找不到。我该怎么做呢?

请注意,如果我使用以下命令:

db.prova.find({"composition.mol_fraction":0})

它查找"mol_fraction“字段之一等于0的所有对象。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-08-08 03:14:33

设计此查询的方法应该是可以动态传递组合数组。

假设我们在DB中有以下数据:

{
    "_id" : ObjectId("5d4b2039cbfa696dcd9924a5"),
    "T_K" : 750,
    "P_Pa" : 2026500,
    "phi" : 1,
    "composition" : [
        {
            "species" : "NC10H22",
            "mol_fraction" : 0
        },
        {
            "species" : "NC12H26",
            "mol_fraction" : 1
        }
    ]
}
{
    "_id" : ObjectId("5d4b20eecbfa696dcd9924a6"),
    "T_K" : 712,
    "P_Pa" : 2026501,
    "phi" : 2,
    "composition" : [
        {
            "species" : "H2",
            "mol_fraction" : 0
        },
        {
            "species" : "O",
            "mol_fraction" : 1
        }
    ]
}
{
    "_id" : ObjectId("5d4b20eecbfa696dcd9924a7"),
    "T_K" : 713,
    "P_Pa" : 2026502,
    "phi" : 2,
    "composition" : [
        {
            "species" : "Na",
            "mol_fraction" : 2
        },
        {
            "species" : "H",
            "mol_fraction" : 1
        },
        {
            "species" : "CO3",
            "mol_fraction" : 4
        }
    ]
}

现在,我们需要搜索:2,1,4

下面的查询可以得到预期的结果:

db.prova.aggregate([
    {
        $match:{
            $expr:{
                $eq:[
                    [2,1,4],
                    {
                        $map:{
                            input:"$composition",
                            as:"composition",
                            in:{
                                $trunc: "$$composition.mol_fraction"
                            }
                        }
                    }
                ]
            }
        }
    }
]).pretty()

输出:

{
    "_id" : ObjectId("5d4b20eecbfa696dcd9924a7"),
    "T_K" : 713,
    "P_Pa" : 2026502,
    "phi" : 2,
    "composition" : [
        {
            "species" : "Na",
            "mol_fraction" : 2
        },
        {
            "species" : "H",
            "mol_fraction" : 1
        },
        {
            "species" : "CO3",
            "mol_fraction" : 4
        }
    ]
}

我们做了什么?

  • 匹配该组合以根据准备的组合进行搜索。该组合物是使用$map聚合器从摩尔分数(按相同顺序)制备的。
票数 0
EN

Stack Overflow用户

发布于 2019-08-07 23:57:10

您需要操作符$in来执行此操作:

db.prova.find({ "composition.mol_fraction": { $in: [ 0, 1 ] }})

编辑:(按特定顺序搜索)

我不知道MongoDB是否像你在对这个答案的评论中所说的那样提供了“过滤优先级”,但是,如果你需要根据数组中按预定顺序出现的值进行过滤,你可以这样做:

db.prova.find({ 
    "composition.0.mol_fraction": 0,
    "composition.1.mol_fraction": 1,
})

这里的缺点是,如果需要查找序列0,1,2 (或更长),则需要根据值列表的大小动态构建查询。

同样,这是可行的,但我不知道是否有更复杂的方法来做到这一点。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57397962

复制
相关文章

相似问题

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