Mongoose 中使用 populate 方法反向查询

阅读时长 5 分钟读完

Mongoose 是一款流行的 MongoDB Node.js ORM 库,它可以方便的帮助我们进行 MongoDB 数据库的增删改查操作。在 Mongoose 中使用 populate 方法,我们可以方便的进行集合间的关联查询,尤其适合用来解决一对多或者多对多的关系。

本文将详细介绍 Mongoose 中的 populate 方法,并结合示例代码进行说明,希望能给大家带来收获和帮助。

什么是 populate 方法?

populate 方法是 Mongoose 中的一个常用方法,它能够通过一个属性引用查询其关联的对象属性。它将在查询文档时,自动填充关联属性的值,使我们得以方便的进行关联属性的查询。

如何使用 populate 方法?

在 Mongoose 中,我们可以使用 populate 方法来完成反向查询。即在查询中,从关联的集合反向查找其关联集合的信息。

我们先来创建一个具有关联关系的数据模型:

-- -------------------- ---- -------
--- -------- - --------------------
--- ------ - ----------------

--- ------------ - --- --------
  ----- -------
  ------ -- ----- ------------------------------- ---- ------- ---
---

--- ---------- - --- --------
  ------ -------
  ------- - ----- ------------------------------- ---- --------- --
---

--- ------ - ------------------------- --------------
--- ---- - ----------------------- ------------

在上述的代码中,我们定义了两个数据模型,一个是 Author,一个是 Book。其中 Author 模型中包含两个属性,一个是名字 name,一个是图书 books 的 Id,books 是一个包含多个 ObjectId 类型的数组,指向另一个数据模型 Book。而 Book 模型中则包含两个属性,一个是书名 title,一个是作者 author 的 Id,author 是一个 ObjectId 类型,指向 Author 集合中的一个作者。

接下来我们来模拟一些测试数据,用于查询操作:

-- -------------------- ---- -------
--- -------- - -- ------ -------- -- ------- -- - ------ --------- ----------- -- - ------ ------------ --- ---------- ------ ---
--- ---------- - -- ----- ------ -- - ----- ----- ---

--------------- -------- -- -
  ------------------------- ------ -
    --- - - --- -----------
    ---------
  ---
---

----------------- -------- -- -
  --------------------------- -------- -
    --- - - --- ---------------
    ------- - ----------------- -----------------
    ---------
  ---
---

在代码中,我们先创建了一个数组 arrBooksarrAuthors,分别保存了三个书籍和两位作者的信息。然后分别使用 Book.removeAuthor.remove 方法删除两个集合的所有文档。最后通过 new Book(book)new Author(author) 方法,创建并保存了对应的文档。

之后我们使用以下代码来查找作者 Mike 发表的书籍:

在查询 Author 集合中的文档后,我们调用 populate("books") 方法,指示 Mongoose 自动填充作者的 books 属性。最后使用中间件 exec 函数来执行查询操作。

输出结果为:

我们发现 author.books 属性已经被成功填充上了 Mike 所发布的两本书。这样我们就能方便的获得与指定书籍作者相关联的信息了。

总结

使用 Mongoose 中的 populate 方法,我们可以方便地进行反向查询操作,可以大大的简化我们的代码,避免了过于繁琐的手动查询操作。希望本文的代码示例以及指导意义能在实际工作中帮助到大家。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6540a4cc7d4982a6eba29e50

纠错
反馈