我需要搜索名为 blog 的集合中的文档,该集合具有为标题,标签,摘要和正文定义的文本索引:
@Document(collection="blog")
public class Blog {
@Id
private String id;
@TextIndexed(weight = 10)
private String title;
@TextIndexed(weight = 9)
private String tags;
@TextIndexed(weight = 8)
private String summary;
@TextIndexed(weight = 7)
private String body;
@TextScore
private Float score;
//getters and setters
}
现在,我需要根据以下标准在 blog 集合上执行文本搜索:
对于第二种情况 TextCriteria 定义如下:
TextCriteria criteria = TextCriteria.forDefaultLanguage().matching("SingleWord");
对于第三种情况,如何在单个查询中编写组合的条件定义:
query 1: db.articles.find( { $text: { $search: "\"coffee cake\"" } } ) //phrase search
query 2: db.articles.find( { $text: { $search: "coffee cake" } } ) //word search
我可以使用
执行搜索query 1 OR query 2 with sorted result based on score.
对于完整短语的匹配结果,分数应该更高。
答案 0 :(得分:1)
MongoRepository还支持对全文文档进行TextCriteria查询。描述为here;
@Document
class FullTextDocument {
@Id String id;
@TextIndexed String title;
@TextIndexed String content;
@TextScore Float score;
}
interface FullTextRepository extends Repository<FullTextDocument, String> {
// Execute a full-text search and define sorting dynamically
List<FullTextDocument> findAllBy(TextCriteria criteria, Sort sort);
// Paginate over a full-text search result
Page<FullTextDocument> findAllBy(TextCriteria criteria, Pageable pageable);
// Combine a derived query with a full-text search
List<FullTextDocument> findByTitleOrderByScoreDesc(String title, TextCriteria criteria);
}
Sort sort = Sort.by("score");
TextCriteria criteria = TextCriteria.forDefaultLanguage().matchingAny("spring", "data");
List<FullTextDocument> result = repository.findAllBy(criteria, sort);
criteria = TextCriteria.forDefaultLanguage().matching("film");
Page<FullTextDocument> page = repository.findAllBy(criteria, PageRequest.of(1, 1, sort));
List<FullTextDocument> result = repository.findByTitleOrderByScoreDesc("mongodb", criteria);
答案 1 :(得分:0)
Spring数据mongodb支持以下文本搜索操作:
第一个标准可以执行文本搜索:search,text1和text2 第二个标准可以执行文本搜索:搜索,术语 第三个标准是短语搜索:'搜索词'
可以使用以上标准形成文本查询:
Query query = TextQuery.queryText(TextCriteria.forDefaultLanguage().matchingAny("search term").sortByScore().with(new PageRequest(pageNum, docCount, new Sort(new Order(Sort.Direction.DESC, "score"))));
要使用得分(文本搜索得分)进行排序,我们需要在相应的POJO中添加一个名为得分的字段:
@TextScore
private Float score;
我们可以在文本查询中添加其他过滤器,如下所示:
query.addCriteria(Criteria.where("city").is("Delhi").and("country).is("India).and("price").lte(200.50).gte(100.50);
最后执行此查询:
List<Product> products = mongoOperations.find(query, Product.class)
默认情况下,Mongodb会为短语匹配分配更高的分数。因此,如果要求词组匹配得分较高,然后普通文本匹配,则不需要首先找到词组匹配。