我试图使用聚合框架(使用ruby)并将日期投影到这样:
db['requests'].aggregate([
{"$project" => {
_id: 0,
method: '$method',
user: '$user',
year: {'$year' => '$timestamp'}
}}])
该文件就像这样:
{
_id: ObjectId("5177d7d7df26358289da7dfd"),
timestamp: ISODate("2013-04-12T03:58:05+00:00"),
method: "POST",
status: "200",
inputsize: "874",
outputsize: "4981",
user: "131"
}
但是我收到以下错误:
Mongo::OperationFailure: Database command 'aggregate' failed: (errmsg: 'exception: can't convert from BSON type EOO to Date'; code: '16006'; ok: '0.0').
这很奇怪,因为如果我在与mongorestore导入的完全相同的数据库上运行它,它可以正常工作。
答案 0 :(得分:20)
问题是我在没有时间戳字段的情况下保存了一些文档。
答案 1 :(得分:2)
如果你需要一些没有这个时间戳字段的文件,你可以尝试这个(我使用Javascript / Mongoose表示法):
year: { $cond: [{ $ifNull: ['$timestamp', 0] }, { $year: '$deliveryDateEnd' }, -1] }
在这种情况下,没有timestamp字段的每个文档都将返回-1。所有其他文件将按预期返回年份。