假设我将数据存储在集合 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" });
那么我们如何动态地做到这一点?
答案 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" });