我正在使用Node.js并尝试使用以下代码将时间戳数据存储在Mongodb数据库中:
`articleProvider.saveUser({
userID : user,
email : email,
address : "",
time : new Date().getTime(),
},function(error,userData){
if(!userData){ callback(error);}
else{ callback(null,userData);}
});
}
});`
存储在数据库中的数据是(来自mongo shell):
{ "userID" : "hem", "email" : "hereshem@gmail.com", "address" : "Kathmandu", "time" : NumberLong("1320911838254"), "_id" : ObjectId("4ebb83dea7dd40990e000002") }
但是,如果我在node.js控制台中检索数据,则输出变为:
{ userID: 'hem',
email: 'hereshem@gmail.com',
address: 'Kathmandu',
time: { low_: -1938088914, high_: 307 },
_id: 4ebb83dea7dd40990e000002 }
现在我的问题是如何使用NumberLong数据检索字段“time”的这个值?
它为输出提供两个不同的字段“low_”和“high_”。但是,我只希望输出“1320911838254”。
任何人都可以帮助我吗?
感谢您的回复。但我试图使用
获取数字var value = new Long(low_bits, high_bits).toNumber();
正如Lycha先生发布的那样,但在Node.js平台中,它显示错误“Long is not defined”:
var value = new Long(user.time.low_, user.time.high_).toNumber();
ReferenceError: Long is not defined
at /home/developer/Desktop/Express/app.js:65:1
at /home/developer/Desktop/Express/public/js/processData.js:76:10
at /home/developer/Desktop/Express/public/js/dbQuery.js:196:16
at [object Object].<anonymous> (/home/developer/node_modules/mongodb/lib/mongodb/collection.js:743:5)
at [object Object].emit (events.js:67:17)
at [object Object].<anonymous> (/home/developer/node_modules/mongodb/lib/mongodb/connections/server.js:97:12)
at [object Object].emit (events.js:64:17)
at Socket.<anonymous> (/home/developer/node_modules/mongodb/lib/mongodb/connection.js:161:16)
at Socket.emit (events.js:64:17)
at Socket._onReadable (net.js:678:14)
如何在node.js中获取长解析器?有什么想法吗?
感谢strada的回应。但是如何在Mongodb中存储dateObject? DataType本身已定义。是否有任何方法可以更改Mongodb中的数据类型? 以及如何解析它?
答案 0 :(得分:3)
经过长期练习后,我找到了最佳解决方案:
articleProvider.saveUser({
userID : user,
email : email,
address : "",
time : new Date().getTime().toString(),
},function(error,userData){
if(!userData){ callback(error);}
else{ callback(null,userData);}
});
}
});
使用“toString()”将日期对象存储为字符串对象,并在查询之后使用“parseInt()”将字符串对象更改为整数值。
我认为这是非常简单和好的解决方案。
答案 1 :(得分:1)
MongoDB将该数字存储为64位对象但javascript不支持,这就是为什么他们必须拥有_low和_high。你可以得到这样的数字:
var value = new Long(low_bits, high_bits).toNumber();
阅读here了解更多信息。您应该考虑使用日期对象。