簡體   English   中英

MONGODB:根據一次查詢查找所有出現的名字或姓氏

[英]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.

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