[英]MONGODB: find all occurencies of first or lastname according to one query
我想根據名字和姓氏查找我的數據庫中的所有事件(邀請用戶在搜索欄中輸入他想要的任何內容),並且我應該返回所有名字或姓氏與該查詢匹配的人。
我已經有了解決方案,但我覺得會有更好的解決方案。 這是我的:
maladeModel.find ({},{nom: 1, prenom: 1, dateNaissance :1, adresse :1, photoIdentite :1},(err, malades) => {
if (err) {
res.status(500).json ({
type: "Err" ,
message : "Server not responding"
});
}
return malades;
}).then (malades=>
{
malades = malades.filter(malade=> {
return malade.nom.toUpperCase().includes(req.body.key.toUpperCase())
||
malade.prenom.toUpperCase().includes(req.body.key.toUpperCase())
});
res.status(200).json ({type :"Info", message: "Le malade est trouve" , malades});
}
);
使用這個 mongodb 聚合內置過濾器始終是最佳使用。
maladeModel.aggregate([
{
$project:{
nom: { $toLower: "$nom" },
prenom: { $toLower: "$prenom" },
dateNaissance :1, adresse :1, photoIdentite :1
}
},
{
$match:{
$or:[
{nom: req.body.key.toLowerCase()},
{prenom: req.body.key.toLowerCase()}
]
}
}
]).exec(function(err, malades) {
res.status(200).json ({type :"Info", message: "Le malade est trouve" , malades});
});
為簡單起見,您可以這樣做
maladeModel.find({
$or:[
{nom: req.body.key.toLowerCase()},
{prenom: req.body.key.toLowerCase()}
]
}, {dateNaissance :1, adresse :1, photoIdentite :1}).then(malades =>{
res.status(200).json({type :"Info", message: "Le malade est trouve" , malades});
}).catch(err => res.status(500).json({message: err.message}))
這將為您提供數據庫中的所有匹配文檔,但我認為索引是最快的。 你可以檢查一下
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.