Javascript 如何通过Mongoose中的对象数组查找?
我有猫鼬。模式如下:Javascript 如何通过Mongoose中的对象数组查找?,javascript,node.js,mongodb,mongoose,mongoose-schema,Javascript,Node.js,Mongodb,Mongoose,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'}, ] 此外,我还有如下对象数组: const pixelSchema = mongoose
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'},
]
此外,我还有如下对象数组:
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!');
}
});
});
将该数组用作查询文档的一部分。运算符允许您对两个或多个表达式的数组执行逻辑或运算,并选择至少满足其中一个表达式的文档 因此,您最终的查询应该是:
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');
}
} );
如果我需要检查所有元素,我只需要使用
$和对吗?