MongoDB的:不能从BSON类型EOO转换为日期(MongoDB: can't conv

2019-09-01 02:03发布

我试图用聚合框架(红宝石)和项目像这样的日期:

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完全相同的数据库运行此。

Answer 1:

问题是,我是不保存时间戳字段的一些文件。



Answer 2:

如果你需要有没有这个时间戳字段的一些文件,你可以试试这个(我使用Javascript /猫鼬符号):

year: { $cond: [{ $ifNull: ['$timestamp', 0] }, { $year: '$deliveryDateEnd' }, -1] }

在这种情况下,如果没有时间戳字段的每个文档将返回-1。 所有其他文件将返回全年预期。



文章来源: MongoDB: can't convert from BSON type EOO to Date