如何使用 Nodejs 在 MongoDB 中创建类似 %keyword% 的查询

Posted

技术标签:

【中文标题】如何使用 Nodejs 在 MongoDB 中创建类似 %keyword% 的查询【英文标题】:How to create like %keyword% query in MongoDB using Nodejs 【发布时间】:2017-08-24 09:58:06 【问题描述】:

我正在开发一个 MEAN 应用程序并希望实现一个搜索过滤器。我在下面的路线中传递搜索关键字如下

router.route("/places/search/:keyword")
    .get(function (req, res) 

        query = ;
        if (req.params.keyword !== undefined) 
            query = 
                name:  '$regex': new RegExp("^" + req.params.keyword.toLowerCase(), "i") 
            ;
        
        var response = ;
        Place.find(query, function (err, data) 
            if (err) 
                response =  "error": true, "message": "Error fetching data" ;
             else 
                response =  "error": false, "message": data ;
            
            res.json(response);
        );
    );

上面的代码正在执行类似keyword% 的搜索,它返回以传递的关键字开头的所有具有name 的位置,但我想获取name 包含keyword 的所有位置,无论是在开头、中间还是结尾,类似于 mysql 中的%keyword%

【问题讨论】:

【参考方案1】:
router.route("/places/search/:keyword")
    .get(function (req, res) 

        query = ;
        if (req.params.keyword !== undefined) 
            query = 
                name: new RegExp(req.params.keyword, 'i')
            ;
        
        var response = ;
        Place.find(query, function (err, data) 
            if (err) 
                response =  "error": true, "message": "Error fetching data" ;
             else 
                response =  "error": false, "message": data ;
            
            res.json(response);
        );
    );

【讨论】:

【参考方案2】:

像 mongodb 和节点 js 一样查询

getSearch(collection, Name) 
     
        var query =  new RegExp(Name,"i")
        
        return this.connect().then(db => 
            return db.collection(collection).find( "title": query).toArray();
          )
        

【讨论】:

以上是关于如何使用 Nodejs 在 MongoDB 中创建类似 %keyword% 的查询的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 PHP 驱动程序在 MongoDB 中创建存储函数

如何使用 async/await 在 NodeJS 中创建 TCP 客户端?

如何在 SEQUELIZE (nodeJS) 中创建触发器?

如何验证MongoDB中是否已有电子邮件的NodeJS

如何使用 nodejs 在用户主目录中创建目录?

如何使用 C++ 在 MongoDB 中创建地理空间索引