当前位置: 首页>>代码示例>>Java>>正文


Java AggregationResults类代码示例

本文整理汇总了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();
}
 
开发者ID:BBVA,项目名称:mirrorgate,代码行数:26,代码来源:ReviewRepositoryImpl.java

示例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;
    }
 
开发者ID:ThoughtWorksInc,项目名称:voter-service,代码行数:19,代码来源:VoteController.java

示例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");
}
 
开发者ID:Just-Fun,项目名称:spring-data-examples,代码行数:22,代码来源:SpringBooksIntegrationTests.java

示例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<>();
}
 
开发者ID:BBVA,项目名称:mirrorgate,代码行数:23,代码来源:FeatureRepositoryImpl.java

示例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;
}
 
开发者ID:BBVA,项目名称:mirrorgate,代码行数:25,代码来源:FeatureRepositoryImpl.java

示例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();

}
 
开发者ID:BBVA,项目名称:mirrorgate,代码行数:34,代码来源:FeatureRepositoryImpl.java

示例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();
}
 
开发者ID:BBVA,项目名称:mirrorgate,代码行数:23,代码来源:FeatureRepositoryImpl.java

示例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();

}
 
开发者ID:BBVA,项目名称:mirrorgate,代码行数:21,代码来源:ReviewRepositoryImpl.java

示例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();

}
 
开发者ID:BBVA,项目名称:mirrorgate,代码行数:18,代码来源:ReviewRepositoryImpl.java

示例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();
}
 
开发者ID:Just-Fun,项目名称:spring-data-examples,代码行数:27,代码来源:OrderRepositoryImpl.java

示例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);
}
 
开发者ID:Just-Fun,项目名称:spring-data-examples,代码行数:19,代码来源:SpringBooksIntegrationTests.java

示例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");
}
 
开发者ID:Just-Fun,项目名称:spring-data-examples,代码行数:21,代码来源:SpringBooksIntegrationTests.java

示例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);
}
 
开发者ID:Just-Fun,项目名称:spring-data-examples,代码行数:28,代码来源:SpringBooksIntegrationTests.java

示例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());
}
 
开发者ID:redlink-gmbh,项目名称:smarti,代码行数:18,代码来源:ConversationRepositoryImpl.java

示例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());
}
 
开发者ID:redlink-gmbh,项目名称:smarti,代码行数:18,代码来源:ConversationRepositoryImpl.java


注:本文中的org.springframework.data.mongodb.core.aggregation.AggregationResults类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。