Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/github/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby MongoDB:can';t从BSON类型EOO转换为日期_Ruby_Mongodb_Aggregation Framework_Database_Nosql - Fatal编程技术网

Ruby MongoDB:can';t从BSON类型EOO转换为日期

Ruby MongoDB:can';t从BSON类型EOO转换为日期,ruby,mongodb,aggregation-framework,database,nosql,Ruby,Mongodb,Aggregation Framework,Database,Nosql,我正在尝试使用聚合框架(结合ruby)并按如下方式预测日期: db['requests'].aggregate([ {"$project" => { _id: 0, method: '$method', user: '$user', year: {'$year' => '$timestamp'} }}]) 文件如下: { _id: ObjectId("5177d7d7df26358289da7dfd"), timestamp: ISODate(

我正在尝试使用聚合框架(结合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导入的数据库完全相同的数据库上运行它,它会正常工作。

问题是我保存了一些没有时间戳字段的文档。

如果您需要一些没有时间戳字段的文档,您可以尝试以下方法(我使用的是Javascript/Mongoose表示法):


在这种情况下,没有timestamp字段的每个文档都将返回-1。所有其他文档都将按预期返回年份。

显然,传递给aggregate()的数组的顺序很重要。如果字段中省略了某些内容,则需要将其添加到$match中,并将$match作为数组中的第一个元素。也就是说,>db.user_account.aggregate([{$match:{“uts”:{$exists:true},“chan_key”:“333261c7a72650a95c68d30cd70”},{$project:{“period_month”:{$month:$uts”},{$group:{{id:{“period_month”:“{“period_month”},number:{$sum:1}}}}})是的!我也是。我搜索了时间戳为“nil”的文档,其中只有一个文档。我修好了,瞧!你能举个例子说明你是如何找到这些文件的吗。
year: { $cond: [{ $ifNull: ['$timestamp', 0] }, { $year: '$deliveryDateEnd' }, -1] }