您的位置:首页 > 数据库 > Mongodb

springdata-mongoTemplate对mongodb去重分页操作

2017-12-29 17:22 375 查看
import org.springframework.data.mongodb.core.aggregation.Aggregation
import org.springframework.data.mongodb.core.mongoTemplate
Criteria criteria = new Criteria();
criteria.and("groupid").in(bean.getGroupId());
List<Order> orders = new ArrayList<Order>();
orders.add(new Order(Direction.ASC, "_id"));
Sort sort = new Sort(orders);
Aggregation agg = Aggregation.newAggregation(
Aggregation.match(criteria),  //查询条件
Aggregation.group("detail"),
Aggregation.sort(sort),
Aggregation.skip((fianlPageNum - 1) * bean.getPageSize()),//跳到第几个开始
Aggregation.limit(bean.getPageSize())//查出多少个数据
);

List<String> details = new ArrayList<String>();
AggregationResults<BasicDBObject> outputType=mongoTemplate.aggregate(agg,TABLE_GROUP_LIST, BasicDBObject.class);
for (Iterator<BasicDBObject> iterator = outputType.iterator(); iterator.hasNext();) {
DBObject obj =iterator.next();
details.add((String) obj.get("_id"));
}
注意:
Aggregation.skip((fianlPageNum - 1) * bean.getPageSize()),
Aggregation.limit(bean.getPageSize())
顺序不能颠倒


`
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: