[英]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.