Aggregation agg = Aggregation.newAggregation(
Aggregation.group(
, OnofflineUserHistoryField.MAC
, StalogField.UTC_CODE)
.sum(OnofflineUserHistoryField.WIFI_UP_DOWN).
as
(OnofflineUserHistoryField.WIFI_UP_DOWN)
.sum(OnofflineUserHistoryField.ACTIVE_TIME).
as
(OnofflineUserHistoryField.ACTIVE_TIME),
Aggregation.project(
"mac"
,
"buildingId"
,
"utcCode"
,OnofflineUserHistoryField.ACTIVE_TIME, OnofflineUserHistoryField.WIFI_UP_DOWN).
and
(
new
AggregationExpression() {
@Override
public
DBObject toDbObject(AggregationOperationContext context) {
return
new
BasicDBObject(
"$cond"
,
new
Object[]{
new
BasicDBObject(
"$eq"
,
new
Object[]{
"$tenantId"
, 0}
),
20161114,
20161114
});
}
}).
as
(
"day"
).andExclude(
"_id"
), 或者
and
(
new
AggregationExpression() {
@Override
public
DBObject toDbObject(AggregationOperationContext context) {
return
new
BasicDBObject(
"$add"
,
new
Object[] { 20141114 });
}
}).
as
(
"day"
).andExclude(
"_id"
),
new
AggregationOperation() {
@Override
public
DBObject toDBObject(AggregationOperationContext context) {
return
new
BasicDBObject(
"$out"
,
"dayStaInfoTmp"
);
}
}).withOptions(options);