【MongoDB】索引 – 文本索引

编程入门 行业动态 更新时间:2024-10-08 22:59:15

【MongoDB】<a href=https://www.elefans.com/category/jswz/34/1771159.html style=索引 – 文本索引"/>

【MongoDB】索引 – 文本索引

一、准备工作

这里准备一些数据

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、创建索引

db.books.createIndex({description: 'text'});

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

2、查询索引

db.books.getIndexes();

结果如下:

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

三、示例:使用英文查询

1、执行查询

db.books.find ({$text: { $search: 'java'}});

结果如下:

2、执行过程

db.books.find ({$text: { $search: 'java'}}).explain();

结果如下:

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

四、示例:使用中文查询

1、执行查询

db.books.find ({$text: { $search: '入门语言'}});

结果如下:

2、执行过程

db.books.find ({$text: { $search: '入门语言'}}).explain();

结果如下:

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

五、示例:使用中文查询

1、执行查询

db.books.find ({$text: { $search: '入门'}});

查询不到任何结果

2、执行过程

db.books.find ({$text: { $search: '入门'}}).explain();

结果如下:

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

3、分析

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

更多推荐

【MongoDB】索引 – 文本索引

本文发布于:2023-11-16 08:50:39,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1615290.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:索引   文本   MongoDB

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!