我有一个MongoDB
可以通过 MongoDB shell 运行的有效聚合查询。但是,我正在尝试将其转换为与官方PHP
Mongo 驱动程序(http://php.net/manual/en/mongocollection.aggregate.php)一起使用。
这是工作的原始 MongoDB 查询:
db.executions.aggregate( [
{ $project : { day : { $dayOfYear : "$executed" } } },
{ $group : { _id : { day : "$day" }, n : { $sum : 1 } } } ,
{ $sort : { _id : -1 } } ,
{ $limit : 14 }
] )
这是我使用 Mongo 驱动程序的尝试(不工作) :PHP
$result = $c->aggregate(array(
'$project' => array(
'day' => array('$dayOfYear' => '$executed')
),
'$group' => array(
'_id' => array('day' => '$day'),
'n' => array('$sum' => 1)
),
'$sort' => array(
'_id' => 1
),
'$limit' => 14
));
上述 PHP 代码的错误是:
{"errmsg":"exception: wrong type for field (pipeline) 3 != 4","code":13111,"ok":0}
有任何想法吗?谢谢。