使用 Mongoose 查找子文档字段与给定条件部分匹配的文档
Find Documents whose Subdocument Fields partially match given Criteria with Mongoose
我已经使用 nodeJS 和 mongoose/mongoDB 构建了一个 API。考虑通用模型 (Gmodel) 的以下模型:
{
name: "teleni",
type: "person",
data: mixed
}
本文档中的数据字段是混合类型,因此它可以是任何类型,但我打算在大多数情况下将其设为 subdocument/object(取决于类型字段的值)。如果我想找到所有类型为 person 的文档,我将执行以下代码:
Gmodel.find({type: "person"}, callbackFunction)
现在考虑模型的另一个实例:
{
name: "teleni",
type: "person",
data: {
data_type: "event",
date: "Jan 30 2019"
}
}
我的问题是我想使用 mongoose 查找数据字段为 object/document 而 data_type 字段为 "event" 的所有文档。我试过以下代码:
Gmodel.find({data: {data_type: "event"}}, callbackFunction)
但是当我执行此代码时没有返回任何内容,因为 find 正在寻找数据字段恰好为 {data_type: "event"}
的文档。那么我如何使用 find 检索其子文档(混合类型)部分匹配条件的文档,类似于 find 在顶级字段上的工作方式。
您可以使用点语法 data.data_type
来指定子文档中的字段。这样它将仅基于此字段进行匹配,而不是像原始代码中那样匹配整个子文档。
Gmodel.find({data.data_type: "event"}, callbackFunction)
我已经使用 nodeJS 和 mongoose/mongoDB 构建了一个 API。考虑通用模型 (Gmodel) 的以下模型:
{
name: "teleni",
type: "person",
data: mixed
}
本文档中的数据字段是混合类型,因此它可以是任何类型,但我打算在大多数情况下将其设为 subdocument/object(取决于类型字段的值)。如果我想找到所有类型为 person 的文档,我将执行以下代码:
Gmodel.find({type: "person"}, callbackFunction)
现在考虑模型的另一个实例:
{
name: "teleni",
type: "person",
data: {
data_type: "event",
date: "Jan 30 2019"
}
}
我的问题是我想使用 mongoose 查找数据字段为 object/document 而 data_type 字段为 "event" 的所有文档。我试过以下代码:
Gmodel.find({data: {data_type: "event"}}, callbackFunction)
但是当我执行此代码时没有返回任何内容,因为 find 正在寻找数据字段恰好为 {data_type: "event"}
的文档。那么我如何使用 find 检索其子文档(混合类型)部分匹配条件的文档,类似于 find 在顶级字段上的工作方式。
您可以使用点语法 data.data_type
来指定子文档中的字段。这样它将仅基于此字段进行匹配,而不是像原始代码中那样匹配整个子文档。
Gmodel.find({data.data_type: "event"}, callbackFunction)