繁体   English   中英

Mongodb:我可以比较一个字段中的值是否包含在另一个字段中

[英]Mongodb: can I compare if value in one field is contained in another field

假设我有一个名为collection_a的集合,其中包含对名为collection_b的集合 b 的查找。 如果集合包含一个名为primary_color的字段,并且查找包含一个名为available_colors的字段。 如何比较primary_coloravailable_colors以查看primary_color的当前值是否包含在available_colors列表中?

我尝试了以下方法,但它在聚合匹配中不起作用,

{'primary_color': {'$in': '$collection_b.available_colors'}}.

$match阶段无法引用另一个集合。

您必须使用$lookup或填充 mongoose。

db.collectiona.aggregate([
  {"$lookup":{
    "from":collectionb,
    "localField":"primary_color",
    "foreignField":"available_colors",
    "as":"matches"
  }},
  {"$match":{"matches.0":{"$exists":true}}}
])

https://mongoplayground.net/p/bkQzZcrP0aJ

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM