位置: 编程技术 - 正文

Mongodb实战之全文搜索功能(mongodb4)

编辑:rootadmin

推荐整理分享Mongodb实战之全文搜索功能(mongodb4),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongodb从入门到商业实战,mongodb bi,mongodb快速入门,mongodb从入门到商业实战,mongodb快速入门,mongodb bi,mongodb最佳实践,mongodb 实战,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

众所周知在传统的关系型数据库中,我们通常将数据结构化,通过一系列表关联、聚合来查询我们所需的结果。而在非结构化的数据中,缺少这种预定义的结构,因而如何快速查询定位到我们所需要的结果,不是一件容易的事。

Mongodb作为一种NoSQL数据库,非常适合存储和管理非结构化数据,例如互联网上的各种文本数据。假如我们用Mongodb存储了很多博客文章,那么如何快速找到所有关于“nodejs”这个主题的文章呢?Mongodb内建的全文搜索可以帮助我们完成这个功能。下面话不多说了,来一起看看详细的介绍:

在本篇博文中,将要介绍的是我使用Mongdb text search的一些经验。

Mongodb text search是什么?

Mongodb text search是Mongodb对数据库进行搜索的功能模块,类似于数据库内建的搜索引擎。有些人可能会疑问,查数据库为什么还需要搜索引擎?直接用条件查询不就得了。例如在前面的文章主题搜索中,我们不可能事先提取出每篇文章的主题,然后用专门的字段存储,因此没办法进行条件查询。并且同一个主题词,有多种不同的表达方式,例如”node”、”nodejs”可视为同一个主题。

Mongodb text search可以自动地对大段的文本数据进行分词处理、模糊匹配、同义词匹配,解决文本搜索的问题。

建立文本索引

要使Mongodb能够进行全文搜索,首先要对搜索的字段建立文本索引。建立文本索引的关键字是text,我们既可以建立单个字段的文本索引,也可以建立包含多个字段的复合文本索引。需要注意的是,每个collection只能建立一个文本索引,且只能对String或String数组的字段建立文本索引。

我们可以通过以下命令,建立一个文本索引:

Mongodb实战之全文搜索功能(mongodb4)

在mongoose中我们可以通过以下代码,创建文本索引:

需要注意的是:由于每个collection只支持一个文本索引,所以当你需要在schema中添加或删除文本索引字段时,往往不起作用。这时候你需要到数据库中,手动删除已经建立的文本索引。

文本搜索示例

文本搜索的语法为:

在mongoose中,我们可以通过以下语句进行文本搜索:

$search后面的关键词可以有多个,关键词之间的分隔符可以是多种字符,例如空格、下划线、逗号、加号等,但不能是-和",因为这两个符号会有其他用途。搜索的多个关键字是or的关系,除非你的关键字包含-。例如hello world会包含所有匹配hello或world的文本,而hello -world只会匹配包含hello且不包含world的文本。

$language指示搜索的语言类型,在最新的Mongodb 3.2 enterprise版本中,已经增加了对中文文本的搜索。

$caseSensitive设置是否区分大小写。

$diacriticSensitive设置是否区别发音符号,CAFÉ于Café是同一语义,只是重音不一样。

我们还可以对搜索的结果按匹配度进行排序:

注意事项

Mongodb建立文本索引时,会对提取所有文本的关键字建立索引,因而会造成一定的性能问题。所以对于结构化的字段,建议用普通的关系查询,如果需要对大段的文本进行搜索,才考虑用全文搜索。

总结

标签: mongodb4

本文链接地址:https://www.jiuchutong.com/biancheng/312664.html 转载请保留说明!

上一篇:mac下安装和配置mongodb的步骤详解(mac安装步骤)

下一篇:Mongo复制集同步验证的实例详解(mongodb怎么复制粘贴)

  • 装修工程人工费占总价比例
  • 空调属于电子设备还是电气设备
  • 研发费用可以结转以后年度抵扣吗对吗
  • 中小企业所得税优惠政策有哪些
  • 进项税额转出补交税金会计分录
  • 虚开发票的受票企业将会受到什么处罚?
  • 小微企业减免的增值税账务处理
  • 停车管理费收费依据
  • 最新定额是哪年
  • 卷烟消费税税率表
  • 房产税从价计征的计税依据
  • 购进材料再销售怎么会计分录
  • 日常管理的基本内容及方法是什么
  • 手表的发票可以报销吗
  • 什么叫市净率?它有何意义?
  • 物业公司收取水电周转金后果
  • 潜在表决权如何影响表决权
  • 付佣金怎么做分录
  • 实习生短期意外保险能企业所得税前扣除吗?
  • 工资税后补扣是什么意思
  • ev4是什么文件
  • php变量如何定义
  • PHP:mb_detect_encoding()的用法_mbstring函数
  • Win11 Build 22000.282正式版推送: 附更新修复内容汇总
  • php获取ftp文件目录
  • 将银行借款存入银行会引起企业资产总额的变化吗
  • kb4592440安装失败
  • 无法偿还应付账款账务处理
  • 审核凭证的操作步骤
  • 跨境电商需要缴纳哪些税种
  • wordpress优化seo
  • element html
  • 如何修改php.ini
  • 利润表利息费用怎么填
  • 银行转账费用试算失败什么意思
  • css字体加粗怎么弄
  • 计算机视觉的应用
  • 角点检测算法
  • opencv图像识别特定形状
  • 税号一般多少位数字
  • 新公司建账会计科目
  • 其他应收账款怎么做预算会计分录
  • 企业报废原材料如何处理
  • 怎么样去掉
  • mongodb数据查询
  • 法人转钱入公户要交税吗
  • 原材料卖出去会计分录
  • 技术人员的工资计入什么费用
  • 定额的个体户怎么交税
  • MySQL提示The InnoDB feature is disabled需要开启InnoDB的解决方法
  • 发票种类包括
  • 股权转让中土地要否缴纳增值税
  • 转出未交增值税借方余额表示什么
  • 补缴增值税的会计处理
  • 公司注销留抵税额怎么做进项转出
  • 计算成本时应该考虑什么
  • 以前年度损益调整借贷方向
  • 代理返利
  • 固定资产处置当月还要折旧吗
  • mysqldump -h
  • 数据库查询排名
  • freebsd联网
  • fedora怎么安装软件
  • 魔方优化大师是免费的吗
  • win7系统换桌面
  • winxp 共享设置
  • dos命令提示符窗口怎么打开
  • win10一年更新几次
  • 2015年win10共发布135个安全补丁 创历年之最
  • android网络框架okhttp
  • js计算字体宽度
  • ubuntu快捷键大全
  • JavaScript中的复杂数据类型又称为
  • input checked选择
  • 广东省电子税务局登录方式
  • 关于房地产企业所得税涉税处理表述正确的有
  • 地下车库是否缴房产税
  • 上海社保联网
  • 河南省税务零申报怎么操作
  • 长沙市税收排名
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设