繁体   English   中英

使用node.js的时间戳mongodb

[英]Timestamp mongodb using node.js

我有一个通过mongodb-native-drivers连接到node.js应用程序的mongodb数据库。 我正在将数据插入数据库,并且需要为其加时间戳,代码如下所示:

var server = new Server('localhost', 27017, { auto_reconnect: true });
var db = new Db('test', server);

exports.fetch = function(args, callback) {
    db.open(function(err, db) {
        db.collection(args['device'], function(err, collection) {
            var doc = {
                          device: args['device'],
                          data: args['data'],
                          time: new db.bson_serializer.Timestamp()
                      }

            collection.insert(doc, { safe: true }, function(err,result) {
                db.close();
                callback(lastestError);
            });
        });
     });
}

插入效果很好,但时间戳始终为0! 我已删除所有错误检查,以确保清晰度和大小。 任何帮助,将不胜感激! 谢谢。

MongoDB文档指出“ Timestamp数据类型,但这是MongoDB的特殊内部类型,通常不应使用”:

http://www.mongodb.org/display/DOCS/Dates

ISODate()是要使用的正确类型。

我认为值0符合预期。 创建对象时,需要提供时间戳的低32位(带符号)和时间戳的高32位(带符号)! 更正将在这里。 “新的db.bson_serializer.Timestamp(someIntLow,someIntHigh)”

有关更多信息,请参见https://github.com/christkv/node-mongodb-native/blob/master/lib/mongodb/bson/timestamp.js#L41

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM