【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或者入门语言进行搜索时都可以查询到结果,而使用入门进行搜索时却无法查询到任何数据。

相关推荐
张璐月2 小时前
mysql join语句、全表扫描 执行优化与访问冷数据对内存命中率的影响
数据库·mysql
全干engineer4 小时前
ClickHouse 入门详解:它到底是什么、优缺点、和主流数据库对比、适合哪些场景?
数据库·clickhouse
Hellyc6 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
lifallen6 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
{⌐■_■}10 小时前
【Kafka】登录日志处理的三次阶梯式优化实践:从同步写入到Kafka多分区批处理
数据库·分布式·mysql·kafka·go
isNotNullX10 小时前
数据中台架构解析:湖仓一体的实战设计
java·大数据·数据库·架构·spark
睿思达DBA_WGX13 小时前
由 DB_FILES 参数导致的 dg 服务器无法同步问题
运维·数据库·oracle
袋鼠云数栈14 小时前
使用自然语言体验对话式MySQL数据库运维
大数据·运维·数据库·后端·mysql·ai·数据治理·数栈·data+ai
阿里云大数据AI技术14 小时前
数据 + 模型 驱动 AI Native 应用发展
大数据·数据库·人工智能