簡體   English   中英

獲取其屬性等於數組中元素之一的所有文檔

[英]Get all documents whose property equals one of the elements in an array

我有一個 Post model 在其架構中定義了publisher者屬性(我使用的是 Mongoose)。 publisher者屬性是一個引用發布者名稱的字符串。

我還有一個名為sourceNames的數組,其中包含所有不同的發布者名稱。 我想在我的數據庫中查詢其publisher者與sourceName中的任何一個數組元素匹配的所有帖子。 我當前的查詢如下所示:

const query = postModel
      .find({ publisher: { $all: sourceNames } })
      .limit(limit)
      .skip(startIndex);

當我執行它時,我的查詢沒有返回任何內容。 有誰知道我正在嘗試做的事情是否可以在單個查詢中進行(而不是遍歷sourceNames並為每個單獨的元素進行查詢?

短的

只需將$all替換為$in


解釋

  • $all正在嘗試將數組與數組中的所有元素進行匹配。

  • $in相反,嘗試將字符串或數組與數組的一個匹配。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM