本文整理汇总了Java中org.springframework.data.mongodb.core.aggregation.AggregationResults类的典型用法代码示例。如果您正苦于以下问题:Java AggregationResults类的具体用法?Java AggregationResults怎么用?Java AggregationResults使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
AggregationResults类属于org.springframework.data.mongodb.core.aggregation包,在下文中一共展示了AggregationResults类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: getAppInfoByAppNames
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public List<ApplicationDTO> getAppInfoByAppNames(List<String> names) {
Aggregation aggregation = newAggregation(
match(Criteria.where("appname").in(names).and("timestamp").exists(true)),
sort(new Sort(DESC, "timestamp")),
project("appname", "platform", "starrating",
"timestamp", "comment", "authorName","url"),
group("appname", "platform")
.push(new BasicDBObject("author", "$authorName")
.append("rate", "$starrating" )
.append("timestamp", "$timestamp")
.append("comment", "$comment")
.append("url", "$url")
).as("reviews"),
project("appname", "platform")
.and("reviews").slice(8, 0)
);
//Convert the aggregation result into a List
AggregationResults<ApplicationDTO> groupResults
= mongoTemplate.aggregate(aggregation, Review.class, ApplicationDTO.class);
return groupResults.getMappedResults();
}
示例2: getWinnersVotesInt
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
private int getWinnersVotesInt() {
Aggregation aggregation = Aggregation.newAggregation(
Aggregation.group("vote").count().as("count"),
project("count"),
sort(Sort.Direction.DESC, "count"),
limit(1)
);
AggregationResults<VoteCountWinner> groupResults =
mongoTemplate.aggregate(aggregation, Vote.class, VoteCountWinner.class);
if (groupResults.getMappedResults().isEmpty()) {
return 0;
}
int result = groupResults.getMappedResults().get(0).getCount();
return result;
}
示例3: shouldRetrieveBooksPerPublisherWithTitles
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
/**
* Get number of books that were published by the particular publisher with their titles.
*/
@Test
public void shouldRetrieveBooksPerPublisherWithTitles() {
Aggregation aggregation = newAggregation( //
group("volumeInfo.publisher") //
.count().as("count") //
.addToSet("volumeInfo.title").as("titles"), //
sort(Direction.DESC, "count"), //
project("count", "titles").and("_id").as("publisher"));
AggregationResults<BooksPerPublisher> result = operations.aggregate(aggregation, "books", BooksPerPublisher.class);
BooksPerPublisher booksPerPublisher = result.getMappedResults().get(0);
assertThat(booksPerPublisher.getPublisher()).isEqualTo("Apress");
assertThat(booksPerPublisher.getCount()).isEqualTo(26);
assertThat(booksPerPublisher.getTitles()).contains("Expert Spring MVC and Web Flow", "Pro Spring Boot");
}
示例4: programIncrementBoardFeatures
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public List<String> programIncrementBoardFeatures(List<String> boards, List<String> programIncrementFeatures){
Aggregation agg = newAggregation(
match(Criteria
.where("sParentKey")
.in(programIncrementFeatures)
.and("keywords")
.in(boards)
),
group()
.addToSet("sParentKey")
.as("features"),
project("features")
.andExclude("_id")
);
AggregationResults<ProgramIncrementBoardFeatures> aggregationResult
= mongoTemplate.aggregate(agg, "feature", ProgramIncrementBoardFeatures.class);
return aggregationResult.getUniqueMappedResult() != null ? aggregationResult.getUniqueMappedResult().features : new ArrayList<>();
}
示例5: getBacklogEstimateByKeywords
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public Double getBacklogEstimateByKeywords(List<String> boards) {
Aggregation agg = newAggregation(
match(Criteria
.where("keywords").in(boards)
.and("sSprintAssetState").ne("ACTIVE")
.and("sTypeName").in(Arrays.asList("Story","Bug"))
.and("sStatus").nin(Arrays.asList("Accepted", "Done"))
),
group()
.sum("dEstimate")
.as("value"),
project("value")
.andExclude("_id")
);
AggregationResults<DoubleValue> groupResults
= mongoTemplate.aggregate(agg, "feature", DoubleValue.class);
DoubleValue val = groupResults.getUniqueMappedResult();
return val == null ? 0 : val.value;
}
示例6: getSprintStatsByKeywords
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public SprintStats getSprintStatsByKeywords(List<String> boards) {
Aggregation agg = newAggregation(
match(Criteria
.where("keywords").in(boards)
.and("sSprintAssetState").is("CLOSED")
.and("sTypeName").in(Arrays.asList("Story","Bug"))
.and("sStatus").in(Arrays.asList("Accepted", "Done"))
),
group("sSprintName")
.first("sprintBeginDate").as("start")
.first("sprintEndDate").as("end")
.sum("dEstimate").as("estimate")
,
group()
.avg("estimate").as("estimateAvg")
.avg(
Ceil.ceilValueOf(
Divide.valueOf(
Subtract.valueOf("end").subtract("start")
).divideBy(3600 * 1000 * 24)
)
).as("daysDurationAvg"),
project("daysDurationAvg","estimateAvg")
.andExclude("_id")
);
AggregationResults<SprintStats> groupResults
= mongoTemplate.aggregate(agg, "feature", SprintStats.class);
return groupResults.getUniqueMappedResult();
}
示例7: getProductIncrementFromPiPattern
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public ProgramIncrementNamesAggregationResult getProductIncrementFromPiPattern(Pattern pi) {
Aggregation agg = newAggregation(
match(Criteria
//.where("keywords").in(boards)
.where("sPiNames").is(pi)
.and("sTypeName").is("Feature")
),
project("sPiNames")
.andExclude("_id"),
unwind("sPiNames"),
group()
.addToSet("sPiNames")
.as("piNames")
);
AggregationResults<ProgramIncrementNamesAggregationResult> aggregationResult
= mongoTemplate.aggregate(agg, "feature", ProgramIncrementNamesAggregationResult.class);
return aggregationResult.getUniqueMappedResult();
}
示例8: getLastReviewPerApplication
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public List<ApplicationReviewsDTO> getLastReviewPerApplication(List<String> names){
Aggregation aggregation = newAggregation(
match(Criteria.where("appname").in(names)),
sort(new Sort(DESC, "timestamp")),
group("appname", "platform")
.first("platform").as("platform")
.first("appname").as("appName")
.first("appname").as("appId")
.first("commentId").as("commentId")
);
//Convert the aggregation result into a List
AggregationResults<ApplicationReviewsDTO> groupResults
= mongoTemplate.aggregate(aggregation, Review.class, ApplicationReviewsDTO.class);
return groupResults.getMappedResults();
}
示例9: getAverageRateByAppNamesAfterTimestamp
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public List<ApplicationDTO> getAverageRateByAppNamesAfterTimestamp(List<String> names, Long timestamp) {
Aggregation aggregation = newAggregation(
match(Criteria.where("appname").in(names).and("timestamp").gte(timestamp)),
group("appname", "platform")
.count().as("votesShortTerm")
.sum("starrating").as("ratingShortTerm")
);
//Convert the aggregation result into a List
AggregationResults<ApplicationDTO> groupResults
= mongoTemplate.aggregate(aggregation, Review.class, ApplicationDTO.class);
return groupResults.getMappedResults();
}
示例10: getInvoiceFor
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
/**
* The implementation uses the MongoDB aggregation framework support Spring Data provides as well as SpEL expressions
* to define arithmetical expressions. Note how we work with property names only and don't have to mitigate the nested
* {@code $_id} fields MongoDB usually requires.
*
* @see example.springdata.mongodb.aggregation.OrderRepositoryCustom#getInvoiceFor(example.springdata.mongodb.aggregation.Order)
*/
@Override
public Invoice getInvoiceFor(Order order) {
AggregationResults<Invoice> results = operations.aggregate(newAggregation(Order.class, //
match(where("id").is(order.getId())), //
unwind("items"), //
project("id", "customerId", "items") //
.andExpression("'$items.price' * '$items.quantity'").as("lineTotal"), //
group("id") //
.sum("lineTotal").as("netAmount") //
.addToSet("items").as("items"), //
project("id", "items", "netAmount") //
.and("orderId").previousOperation() //
.andExpression("netAmount * [0]", taxRate).as("taxAmount") //
.andExpression("netAmount * (1 + [0])", taxRate).as("totalAmount") //
), Invoice.class);
return results.getUniqueMappedResult();
}
示例11: shouldRetrieveBooksPerPublisher
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
/**
* Get number of books that were published by the particular publisher.
*/
@Test
public void shouldRetrieveBooksPerPublisher() {
Aggregation aggregation = newAggregation( //
group("volumeInfo.publisher") //
.count().as("count"), //
sort(Direction.DESC, "count"), //
project("count").and("_id").as("publisher"));
AggregationResults<BooksPerPublisher> result = operations.aggregate(aggregation, "books", BooksPerPublisher.class);
assertThat(result).hasSize(27);
assertThat(result).extracting("publisher").containsSequence("Apress", "Packt Publishing Ltd");
assertThat(result).extracting("count").containsSequence(26, 22, 11);
}
示例12: shouldRetrieveDataRelatedBooks
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
/**
* Filter for Data-related books in their title and output the title and authors.
*/
@Test
public void shouldRetrieveDataRelatedBooks() {
Aggregation aggregation = newAggregation( //
match(Criteria.where("volumeInfo.title").regex("data", "i")), //
replaceRoot("volumeInfo"), //
project("title", "authors"), //
sort(Direction.ASC, "title"));
AggregationResults<BookAndAuthors> result = operations.aggregate(aggregation, "books", BookAndAuthors.class);
BookAndAuthors bookAndAuthors = result.getMappedResults().get(1);
assertThat(bookAndAuthors.getTitle()).isEqualTo("Spring Data");
assertThat(bookAndAuthors.getAuthors()).contains("Mark Pollack", "Oliver Gierke", "Thomas Risberg", "Jon Brisbin",
"Michael Hunger");
}
示例13: shouldRetrievePagesPerAuthor
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
/**
* Retrieve the number of pages per author (and divide the number of pages by the number of authors).
*/
@Test
public void shouldRetrievePagesPerAuthor() {
Aggregation aggregation = newAggregation( //
match(Criteria.where("volumeInfo.authors").exists(true)), //
replaceRoot("volumeInfo"), //
project("authors", "pageCount") //
.and(ArithmeticOperators.valueOf("pageCount") //
.divideBy(ArrayOperators.arrayOf("authors").length()))
.as("pagesPerAuthor"),
unwind("authors"), //
group("authors") //
.sum("pageCount").as("totalPageCount") //
.sum("pagesPerAuthor").as("approxWritten"), //
sort(Direction.DESC, "totalPageCount"));
AggregationResults<PagesPerAuthor> result = operations.aggregate(aggregation, "books", PagesPerAuthor.class);
PagesPerAuthor pagesPerAuthor = result.getMappedResults().get(0);
assertThat(pagesPerAuthor.getAuthor()).isEqualTo("Josh Long");
assertThat(pagesPerAuthor.getTotalPageCount()).isEqualTo(1892);
assertThat(pagesPerAuthor.getApproxWritten()).isEqualTo(573);
}
示例14: findTagsByPattern
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public List<String> findTagsByPattern(Pattern pattern, int limit) {
final Aggregation agg = newAggregation(
project("meta.tags"),
unwind("tags"),
group("tags").count().as("count"),
project("count").and("tags").previousOperation(),
match(where("tags").regex(pattern)),
sort(Direction.ASC, "tags"),
limit(limit));
final AggregationResults<DBObject> results = mongoTemplate.aggregate(agg, Conversation.class, DBObject.class);
return results.getMappedResults()
.stream()
.map(i -> (String) i.get("tags"))
.collect(Collectors.toList());
}
示例15: findTags
import org.springframework.data.mongodb.core.aggregation.AggregationResults; //导入依赖的package包/类
@Override
public List<Pair<String, Long>> findTags(long limit, long offset) {
final Aggregation agg = newAggregation(
project("meta.tags"),
unwind("tags"),
group("tags").count().as("count"),
project("count").and("tags").previousOperation(),
sort(Direction.DESC, "count"),
skip(offset),
limit(limit));
final AggregationResults<DBObject> results = mongoTemplate.aggregate(agg, Conversation.class, DBObject.class);
return results.getMappedResults()
.stream()
.map(i -> new ImmutablePair<>((String) i.get("tags"), (long) i.get("count")))
.collect(Collectors.toList());
}