【MongoDB】索引 – 文本索引

一、准备工作

这里准备一些数据

bash 复制代码
db.books.insertMany([
    {_id: 1, name: "Java", description: "java 入门图书", translation: [{ language: "english", description: "java basic book" }]},
    {_id: 2, name: "C++", description: "C++ 入门图书", translation: [{ language: "english", description: "c++ basic book" }]},
    {_id: 3, name: "Java设计模式", description: "java 设计模式", translation: [{ language: "english", description: "c++ design mode" }]}
]);

二、创建索引

1、创建索引

bash 复制代码
db.books.createIndex({description: 'text'});

上面创建了description字段的文本索引

2、查询索引

bash 复制代码
db.books.getIndexes();

结果如下:

可以看到多了一个名称为description_text的索引;另外可以看到索引中有权重(weights)、默认语言(default_language)、指定语言字段(language_override)、文本索引版本(textIndexVersion)

三、示例:使用英文查询

1、执行查询

bash 复制代码
db.books.find ({$text: { $search: 'java'}});

结果如下:

2、执行过程

bash 复制代码
db.books.find ({$text: { $search: 'java'}}).explain();

结果如下:

可以看到查询过程中会使用到索引名称为description_text的索引

四、示例:使用中文查询

1、执行查询

bash 复制代码
db.books.find ({$text: { $search: '入门语言'}});

结果如下:

2、执行过程

bash 复制代码
db.books.find ({$text: { $search: '入门语言'}}).explain();

结果如下:

可以看到查询过程中会使用到索引名称为description_text的索引

五、示例:使用中文查询

1、执行查询

bash 复制代码
db.books.find ({$text: { $search: '入门'}});

查询不到任何结果

2、执行过程

bash 复制代码
db.books.find ({$text: { $search: '入门'}}).explain();

结果如下:

可以看到查询过程中会使用到索引名称为description_text的索引

3、分析

在创建文本索引时,会先对文本进行分词,根据分词后的结果建立索引;这里分词使用的是空格,所以使用java或者入门语言进行搜索时都可以查询到结果,而使用入门进行搜索时却无法查询到任何数据。

相关推荐
枫叶丹42 小时前
【Qt开发】Qt窗口(九) -> QFontDialog 字体对话框
c语言·开发语言·数据库·c++·qt
w_t_y_y7 小时前
Nginx Plus
运维·数据库·nginx
川贝枇杷膏cbppg8 小时前
dm_unknown_202512.log:达梦数据库 “未分类日志“
数据库·oracle
计算机毕设VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue图书商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
求学中--8 小时前
MySQL 数据库完整操作命令与使用指南
数据库·sql·mysql·oracle
DKunYu9 小时前
误删数据库表导致出现1146报错
数据库
惜分飞11 小时前
sql server 事务日志备份异常恢复案例---惜分飞
前端·数据库·php
sunddy_x11 小时前
MySQL入门
数据库·mysql
_Minato_11 小时前
数据库知识整理——数据库设计的步骤
数据库·经验分享·笔记·软考
坐吃山猪12 小时前
BrowserUse14-源码-ScreenShot模块-整理
linux·数据库·python