【发布时间】:2015-05-31 01:58:44
【问题描述】:
我有以下 Mongo 聚合查询:
db.getCollection('datas').aggregate(
{
"$match":{
"payload.category_ids":ObjectId("5502b04bee60fc1ed06e2fa4"),
"time":{ "$gte":new Date(2015,4,22) }
}
},
{
"$group":{
_id: "$user_id",
num_use: {"$sum":1}
}
},
{
"$sort":{"num_use":-1}
},
{
"$match": {
'num_use':{"$gte":10}
}
}
)
我正试图将其转换为 PHP Mongo 查询:
$topUserCat = $datas->aggregate(
array(
array('$match'=>
array(
'payload.category_ids'=>new MongoId($category_id),
'time'=>array('$gte'=>new MongoDate(strtotime('-1 week')))
)
)
),
array(
'$group'=>array(
'_id'=>'$user_id',
'num_use'=>array('$sum'=>1)
)
),
array(
'$match'=>array(
"num_use"=>array('$gte'=>10)
)
)
);
没有最后一个匹配项,此查询在 PHP 中有效。然而,最终匹配在顶部的 Mongo 查询中有效,所以我觉得我在 PHP 查询中遗漏了一些东西。我目前得到的错误是异常:管道元素 0 不是对象'
【问题讨论】: