Spring data mongodb 聚合查詢(aggregation) 之 project

project :控制返回的字段,例如一個實體類,我們只需要部分字段

1 插入數據

        mongoTemplate.save(new Role("zhang1",5));
        mongoTemplate.save(new Role("zhang2",6));
        mongoTemplate.save(new Role("zhang3",12));
        mongoTemplate.save(new Role("zhang4",14));
        mongoTemplate.save(new Role("zhang5",23));

2 查詢:查詢name是zhang1的 數量

TypedAggregation<Role> agg = Aggregation.newAggregation(Role.class,Aggregation.match(Criteria.where("name").is("zhang1")),
                Aggregation.count().as("count1"),
                Aggregation.project("count1"));
        AggregationResults<Document> result = mongoTemplate.aggregate(agg,Document.class);
        result.getMappedResults().forEach(document -> System.out.println(document));

3 結果

Document{{count1=1}}

4 注意:

這裏多個Aggregation 是按先後順序執行的,即後面一個在前面一個的基礎上作篩選等操作,所以順序不一致可能會報錯

例如:先count,再match,最後project

先count只會有一個count1 的字段,再執行match時只能對count1 進行操作


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章