Given below the following data structure of a document:
{
"_id" : x,
"device_model_id": x,
"device_os_id": x,
"device_status_id" : x,
}
I would like to group the data by device_status and device_os:
{u'ok': 1.0, u'result': [
{
u'_id': {u'device_os_id': 2, u'device_status_id': 2},
u'total': $sum,
u'models': {
'device_model_id': 1,
'total_device_model': $sum
}
},
{
u'_id': {u'device_os_id': 1, u'device_status_id': 1},
u'total': $sum,
u'models': {
'device_model_id': 4,
'total_device_model': $sum
}
},
.....
So far I have the following code:
testing = self.collection.aggregate([
{'$group': {
'_id': {'device_os_id': "$device_os_id", 'status': '$device_status_id'},
'total': {'$sum': 1},
'models': {'$addToSet': "$device_model_id"},
}}
])
which gives me the following result:
{u'ok': 1.0, u'result': [
{u'total': 20355, u'models': [18, 2, 3], u'_id': {u'device_os_id': 2, u'status': 2}},
{u'total': 38429, u'models': [18, 19, 2, 3], u'_id': {u'device_os_id': 2, u'status': 1}},
{u'total': 1, u'models': [15], u'_id': {u'device_os_id': 1.0, u'status': 1}}]}
I haven't found a way to add the sum of each device_model_id to the 'models' list. Does anyone know how I can acheive this? Many thanks for your help.