如何在猫鼬中按对象数组查找

How to find by array of objects in Mongoose?

本文关键字:对象 数组 查找      更新时间:2023-09-26

我有像这样的Mongoose.Schema:

const pixelSchema = mongoose.Schema({
  x: String,
  y: String,
  color: String,
});

我也有这样的对象数组:

let pixels = [
  {x: 0, 1: 0, color: 'blue'},
  {x: 0, y: 1, color: 'blue'},
  {x: 0, y: 2, color: 'blue'},
]

如何检查数据库中是否已存在此元素之一?我的解决方案现在看起来像这样,但我认为它效率非常低。

pixels.map(pixel => {
  Pixel.find(pixel, (err, pixels) => {
    if (pixels) {
      console.log('Find!');
    }
  });
});

将该数组用作$or查询文档的一部分。 $or运算符允许您对包含两个或多个表达式的数组执行逻辑 OR 运算,并选择至少满足其中一个表达式的文档。

所以你的查询最终应该只是:

let pixels = [
  {x: 0, y: 0, color: 'blue'},
  {x: 0, y: 1, color: 'blue'},
  {x: 0, y: 2, color: 'blue'},
];
let query = { "$or": pixels };
Pixel.find(query, (err, pixels) => {
    if (pixels) {
        console.log('Find!');
    }
});
你可以

试试像

let pixels = [
  {x: 0, 1: 0, color: 'blue'},
  {x: 0, y: 1, color: 'blue'},
  {x: 0, y: 2, color: 'blue'}
]
Pixel.find({ "$or": pixels}, function(error, pixel) {
    if(pixel) {
        console.log('Found pixel');
    }
} );