从嵌套的 json 中查找猫鼬集合中的值

时间:2021-03-16 07:33:11

标签: node.js mongodb mongoose mongoose-schema

假设我将数据存储在集合 Teacher 中:

{
    "name":"john",
    "age":45,
    "class_access":{
        1234:"head",
        1235:"head
    },
    "_id" : ObjectId("12312312"),
}

{
    "name":"henry",
    "age":55,
    "class_access":{
        1234:"head",
    },
    "_id" : ObjectId("sdf9991"),
}

{
    "name":"travis",
    "age":35,
    "class_access":{
        2341:"head",
    },
    "_id" : ObjectId("sas21"),
}

我想找到1234班所有老师的所有信息。

为此我尝试过:

 const TeacherDetails = await Teacher.find({ class_access: {1234:"head"} })

但它没有返回任何东西。 那么如何访问嵌套的 json 以获取所有详细信息?

如果有人需要任何进一步的信息,请告诉我。

根据 Arif 先生提供的解决方案 const TeacherDetails = await Teacher.find({ "class_access.1234": "head" });

支持类值不是恒定的,说我是从变量中获取的

const className = 1234

现在,如果我尝试获取 className,则会出现语法错误,我尝试对所有这些都遵循以下语法错误

const TeacherDetails = await Teacher.find({ class_access.className: "head" });

const TeacherDetails = await Teacher.find({ class_access[className]: "head" });

const TeacherDetails = await Teacher.find({ 'class_access.+'${className}': "head" });

那么我们如何动态地做到这一点?

1 个答案:

答案 0 :(得分:1)

由于 class_access 表示可能有多个键的对象,您应该尝试像

您可以使用 [variableName] 作为键,如下所示

方法一:使用字符串模板

const className = 1234
const TeacherDetails = await Teacher.find({ [`class_access.${className }`]: "head" });

方法 2:使用字符串连接

const className = 1234
const classAccess = 'class_access.' + className;
const TeacherDetails = await Teacher.find({ [classAccess] : "head" });
相关问题