Search code examples
node.jsmongodbmongoosemongoose-populatemongodb-lookup

MongoDB $lookup vs Mongoose populate


I have seen this and other similar titled questions, none answer my question.

I was going through the mongoose documentation where I read

MongoDB has the join-like $lookup aggregation operator in versions >= 3.2. Mongoose has a more powerful alternative called populate(), which lets you reference documents in other collections.

How does populate() in mongoose work that makes it more powerful than MongoDB's $lookup?

Isn't mongoose a tool that helps nodejs users work with mongodb. If so how can mongoose have functionalities that MongoDB does not? Like populate()?

Does mongoose's populate() method use MongoDB's $lookup behind the scenes?


Solution

  • Thanks to a github thread shared by Grégory NEUT in the question's comments I have been able to establish certain facts:

    1. Mongoose's populate() method does not use MongoDB's $lookup behind the scenes. It simply makes another query to the database.
    2. Mongoose does not have functionalities that MongoDB does not have. populate() just makes two or more queries.

    How does populate() in mongoose work that makes it more powerful than MongoDB's $lookup?

    In my opinion, there are places to use populate() and others to use $lookup. For more complex queries $lookup in an aggregation pipeline would work best.