1

如何将一个简单的 mongo shell $match 短语翻译成它在 Java 中的 mongo-spring 中等效 - 使用聚合?

$match: { $text: { $search: "read" } } 
4

1 回答 1

1

Spring-data 内置了对文本搜索的支持。

我使用了以下依赖项:

<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-mongodb</artifactId>
    <version>1.8.2.RELEASE</version>
</dependency>

尝试以下语法:

TextCriteria criteria = TextCriteria.forDefaultLanguage().matchingAny("read");

Query query = TextQuery.queryText(criteria);    

List<klass> list = mongoTemplate.find(query, klass, "collection_name");

有关更多详细信息,请参阅

要在聚合中执行相同操作,请使用以下语法:

BasicDBObject match = new BasicDBObject("$match", 
                new BasicDBObject("$text", new BasicDBObject("$search", "COST")));

List<DBObject> aggregationList = new ArrayList<DBObject>();
aggregationList.add(match);

AggregationOutput aggregationOutput = mongoTemplate.getCollection("categoryMaster")
        .aggregate(aggregationList);

List<DBObject> dbObjects = (List<DBObject>) aggregationOutput.results();

将其转换dbobjectsklass如下:

for(DBObject dbObject : dbObjects) {
    mongoTemplate.getConverter().read(klass, dbObject);
}
于 2016-01-21T10:03:27.710 回答