nodejs + mongodb实现模糊查询与全文搜索

   2023-02-09 学习力0
核心提示: mongodb中的查询条件   关键字说明$or或关系$nor或关系取反$gt大于$gte大于等于$lt小于$lte小于等于$ne不等于$in在多个值范围内$nin不在多个值范围内$all匹配数组中多个值$regex正则,用于模糊查询$size匹配数组大小$maxDistance范围查询,距离(基于LBS

 

mongodb中的查询条件

 

 

 

关键字 说明
$or 或关系
$nor 或关系取反
$gt 大于
$gte 大于等于
$lt 小于
$lte 小于等于
$ne 不等于
$in 在多个值范围内
$nin 不在多个值范围内
$all 匹配数组中多个值
$regex 正则,用于模糊查询
$size 匹配数组大小
$maxDistance 范围查询,距离(基于LBS)
$mod 取模运算
$near 邻域查询,查询附近的位置(基于LBS)
$exists 字段是否存在
$elemMatch 匹配内数组内的元素
$within 范围查询(基于LBS)
$box 范围查询,矩形范围
$center 范围查询,圆形范围
$centerSphere 范围查询,球形范围
$slice 查询字段集合中的元素(比如从第几个之后,第N到第M个元素)

 

mongodb中的查询语句

db.movies.find({'name':/未来/})
db.collection.find( { field: { $regex: 'acme.*corp', $options: 'i' } } );

官方举例是通过 '/.../' 和$regex,这两种都可以查询到结果。

现在我想实现查询标题关键字匹配到对应文章。

如下:

1.查询title字段中包含某个字符串的集合:

 Article.find({"title":{$regex: /searchValue/,$options:'i'}}, (err, data) => { // {"title": /searchValue/} $options:'i' 表示忽略大小写
        if(err) {
            console.log(err)
            return res.status(500).json({
                result: 1,
                error_info: err.message
            })
        }
        console.log(data)
        let length = data.length
        return res.status(200).json({
            result: 0,
            count: length,
            searchArticle: data
        })
    })
searchValue是前端传过来的查询关键词。

这么写好像没有问题,跟官方实例一样,但是查询不到结果。

请注意,MongoDB的的模糊查询是通过正则表达式实现的,对应mongodb中,可以直接使用 ‘/../’ 斜杠。
但是在nodejs中,必须要使用RegExp,来构建正则表达式对象。

router.post('/like_article_search', (req,res) => {
    let searchValue = req.body.value
    console.log(searchValue)
    var str=".*"+searchValue+".*$"
    var reg = new RegExp(str)

    Article.find({"title":{$regex:reg,$options: 'i'}}, (err, data) => { // $options:'i' 表示忽略大小写
        if(err) {
            console.log(err)
            return res.status(500).json({
                result: 1,
                error_info: err.message
            })
        }
        console.log(data)
        let length = data.length
        return res.status(200).json({
            result: 0,
            count: length,
            searchArticle: data
        })
    })
})

 

这样就可以匹配到查询结果。

2.查询以某个字母开头的集合

mongodb语法:

db.UserInfo.find({userName :/^A/})

nodejs中写法:

router.post('/like_article_search', (req,res) => {
    let searchValue = req.body.value
    console.log(searchValue)
    var str="^.*"+searchValue+".*$"
    var reg = new RegExp(str)

    Article.find({"title":{$regex:reg,$options: 'i'}}, (err, data) => { // {"title": /searchValue/} $options:'i' 表示忽略大小写
        if(err) {
            console.log(err)
            return res.status(500).json({
                result: 1,
                error_info: err.message
            })
        }
        console.log(data)
        let length = data.length
        return res.status(200).json({
            result: 0,
            count: length,
            searchArticle: data
        })
    })
})

3.多条件模糊查询

使用$or 语法。

多字段匹配,title、categroy、lable中包含查询关键词的都进行匹配

//模糊查询
router.post('/like_article_search', (req,res) => {
    let searchValue = req.body.value
    // console.log(searchValue)
    // var str=".*"+searchValue+".*$"
    // var reg = new RegExp(str)
    var reg = new RegExp(searchValue);
    var _filter = {
    //多字段匹配
        $or: [
            {'title': {$regex: reg}},
            {'categroy': {$regex: reg}},
            {'lable': {$regex: reg}},
        ]
    }

    Article.find(_filter, (err, data) => { // {"title": /searchValue/} $options:'i' 表示忽略大小写
        if(err) {
            console.log(err)
            return res.status(500).json({
                result: 1,
                error_info: err.message
            })
        }
        console.log(data)
        let length = data.length
        return res.status(200).json({
            result: 0,
            count: length,
            searchArticle: data
        })
    })
})

这样就可以实现。还可以通过某个字段对搜索结果进行降序或升序排列。

 4.全文搜索

 

上述正则表达是在效率上等同在该字段上进行全部扫描(除了在该字段上建立索引并使用^符号进行查找,该操作是会走索引的),当需要正则搜索的文档到了一定的量级,模糊是查询的效率还是会很低的。

 

全文搜索就是在需要搜索的字段上加上一个文本索引,注意:一个集合只能支持建立一个全文索引,但该索引可以包含多个字段做联合索引。

Mongo的 $text 和 $search 相关的内容,这是Mongo内置的全文检索,支持多种语言,支持词语权重,在最新的Mongodb 3.2 enterprise版本中,已经增加了对中文文本的搜索。

数据库结构

nodejs + mongodb实现模糊查询与全文搜索

 

 

 创建索引

MongoDB提供文本索引以支持对字符串内容的文本搜索查询。text索引可以包括其值为字符串或字符串元素数组的任何字段。 要执行文本搜索查询,必须text在集合上有 索引。集合只能有一个 文本搜索索引,但该索引可以涵盖多个字段。

 

articleSchema.index({title: 'text', content: 'text', categroy: 'text'})

查询

使用$text查询运算符对具有文本索引的集合执行文本搜索。 $text将使用空格和大多数标点符号作为分隔符来标记搜索字符串,并OR在搜索字符串中执行所有此类标记的逻辑

router.post('/like_article_search', (req,res) => {
    let searchValue = req.body.value
    
    //正则匹配 
    var reg = new RegExp(searchValue);
    
    Article.find({$text:{$search: reg}},{score: {$meta: "textScore"}})
    .sort({score:{$meta: "textScore"}}) 
    .exec((err, data) => { 
        if(err) {
            console.log(err)
            return res.status(500).json({
                result: 1,
                error_info: err.message
            })
        }
        console.log(data)
        let length = data.length
        return res.status(200).json({
            result: 0,
            count: length,
            searchArticle: data
        })
    })
})

默认情况下,mongodb将以未排序的顺序返回结果。如果要按照相关性得分的顺序进行排序,需要明确的指出对字段进行映射和排序:$meta: textScore

nodejs + mongodb实现模糊查询与全文搜索

 推荐文章:https://blog.csdn.net/wukongbajieheti/article/details/99715743

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 打造自己的 nodejs 静态文件服务器(帖子内容,
    用NodeJS打造你的静态文件服务器在《The Node Beginner Book》的中文版(http://nodebeginner.org/index-zh-cn.html)发布之后,获得国内的好评。也有同学觉得这本书略薄,没有包含进阶式的例子。@otakustay同学说:“确实,我的想法是在这之上补一个简单的MV
    02-10
  • NodeJS无所不能:细数10个令人惊讶的NodeJS开源
    在几年的时间里,NodeJS逐渐发展成一个成熟的开发平台,吸引了许多开发者。有许多大型高流量网站都采用NodeJS进行开发,像PayPal,此外,开发人员还可以使用它来开发一些快速移动Web框架。  除了Web应用外,NodeJS也被应用在许多方面,本文盘点了NodeJS在其
    02-10
  • Linux环境下的Nodejs linux安装基本环境
    最近在学习Node.js,在window下总是觉得不那么爽快。最简单而且环保的方法是在虚拟机中安装一个Linux。 { 1.Linux:家中的Linux为Centos。 2.VirtuallyBox: 开启2块网卡。第一个选Host-Only目的是为了让虚拟机通上网。第二块选Bridge Adapter,这是为了
    02-09
  • nodejs package.json说明
    {"name": "test", //项目名称(必须),由小写英文字母、数字和下划线,不能含空格"version": "1.0.0", //项目版本(必须)"description": "This is for study gulp project !", //项目描述(必须)"homepage": "", //项目主页url " key
    02-09
  • 017 nodejs取参四种方法req.body,req.params,re
    摘要: nodejs取参四种方法req.body,req.params,req.param,req.body 获取请求很中的参数是每个web后台处理的必经之路,nodejs提供了四种方法来实现。获取请求很中的参数是每个web后台处理的必经之路,nodejs的 express框架 提供了四种方法来实现。req.bodyre
    02-09
  • Docker windows下安装并搭建Nodejs的webapp
    Docker windows下安装并搭建Nodejs的webapp
    一、关于Docker什么是Docker?Docker 采用go语言编写,是一个开源的应用容器引擎。让开发者可以快速打包他们的应用以及依赖包到一个封装的可移植的容器Image中,然后发布到任何流行的机器( Linux ,windows,Mac等)上,也可以实现虚拟化。容器是使用完全
    02-09
  • Nodejs+Express+Mysql实现简单用户管理增删改查
    Nodejs+Express+Mysql实现简单用户管理增删改查
     源码地址  https://github.com/king-y/NodeJs/tree/master/user目录结构  mysql.jsvar mysql = require('mysql');var pool = mysql.createPool({host : '127.0.0.1',user : 'root',password : '',database : 's79'});exports.que
    02-09
  • nodejs查看本机hosts文件域名对应ip
    const dns = require('dns')dns.lookup('domainName', function(err, result) {console.log(result)}) related:https://***.com/questions/36689536/how-to-resolve-hostname-to-an-ip-address-in-node-js
    02-09
  • nodejs process.memoryUsage() rss等参数啥含义
    nodejs process.memoryUsage() rss等参数啥含义
    1 前言使用process.memoryUsage() ,然后可以得到一个对象如下:{ rss: 4935680,heapTotal: 1826816,heapUsed: 650472,external: 49879}  然而不知道rss是什么缩写,不知道其含义,网上找了一圈,多数都没说到点上,我这边就补充一下,也作为记录使用。2 
    02-09
  • nodejs工程拷贝后运行报module找不到问题
    工程文件夹通过复制黏贴到另外一个地方,运行后报错 “can`t find module 某某某”,查看原因:输入node 进入控制台,输入console.log(module.paths)查看当前nodejs查找module的路径,如果没有工程里的node_modules,通过module.paths.push加入,检查是否有效
    02-09
点击排行