使用 Mongoose 查找子文档字段部分匹配给定条件的文档

Posted

技术标签:

【中文标题】使用 Mongoose 查找子文档字段部分匹配给定条件的文档【英文标题】:Find Documents whose Subdocument Fields partially match given Criteria with Mongoose 【发布时间】:2019-11-03 14:27:21 【问题描述】:

我使用 nodeJS 和 mongoose/mongoDB 来构建 API。考虑以下通用模型(Gmodel)的模型:


   name: "teleni",
   type: "person",
   data: mixed

本文档中的数据字段是混合类型,因此它可以是任何类型,但我打算在大多数情况下将其作为子文档/对象(取决于类型字段的值)。如果我想查找所有类型为 person 的文档,我将执行以下代码:

Gmodel.find(type: "person", callbackFunction)

现在考虑另一个模型实例:


   name: "teleni",
   type: "person",
   data: 
      data_type: "event",
      date: "Jan 30 2019"
   

我的问题是我想使用 mongoose 来查找数据字段为对象/文档且 data_type 字段为“事件”的所有文档。我试过以下代码:

Gmodel.find(data: data_type: "event", callbackFunction)

但是,当我执行此代码时没有返回任何内容,因为 find 正在查找数据字段恰好为 data_type: "event" 的文档。那么如何使用 find 来检索子文档(混合类型)部分匹配条件的文档,类似于 find 在***字段上的工作方式。

【问题讨论】:

【参考方案1】:

您可以使用点语法data.data_type 来指定子文档中的字段。这样,它将仅基于此字段进行匹配,而不是原始代码中的整个子文档。

Gmodel.find(data.data_type: "event", callbackFunction)

【讨论】:

以上是关于使用 Mongoose 查找子文档字段部分匹配给定条件的文档的主要内容,如果未能解决你的问题,请参考以下文章

在 Mongoose/MongoDB 的文档中过滤数组、子文档、数组、文档

如何在不使用 _id 字段但使用多个属性的情况下在 mongoose 中查找子文档

如何在 Mongoose 中找到与数组字段的最后一个元素与给定查询值匹配的所有文档?

Mongoose 按查找字段分组

如何使用另一个集合 mongoose 查找子查询文档

具有必填子文档字段的 Mongoose 架构