MongoDB的objectid常见忘写时间,取当时时间的方法是什么
Admin 2022-05-31 群英技术资讯 563 次浏览
MongoDB默认使用_id字段作为主键,类型为ObjectId。ObjectId的生成有一定的规则。如果你在写入数据库的时候忘记写入创建时间,不用担心,完全可以通过_id字段的值来还原当时的时间。看下面的mongodb script脚本:
db.getCollection('fees').find({}).forEach(function(item){ var _str = item._id.toString().substr(10, 8); var _date = new Date(Number(parseInt(_str, 16).toString() + '000')); item.createTime = _date; db.fees.save(item); })
forEach可以遍历collection中的每一条数据,然后逐一进行修改。item._id.toString()会将整个ObjectId("...")当成一个字符串来处理,然后从第10个字符开始,取8个字符,得到的是这条数据创建时的时间戳(不带毫秒位数)。在后面补上毫秒位数”000“,然后用Date()方法构造成时间对象,赋值给createTime属性。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
mongodb和redis的区别:1、两者内存管理机制不同。2、两者支持的数据结构不同。3、性能上Redis优于MongoDB。4、可靠性上MongoDB优于Redis。
这篇文章主要给大家分享mongodb添加arbiter节点的步骤和过程,对大家了解mongodb添加节点有一定的帮助,感兴趣的朋友可以参考一下,希望大家阅读完这篇文章能有所收获,下面我们一起来学习一下吧。
在mongodb中存入日期的方法:1、登录MongoDBshell;2、通过插入项创建数据库;3、把这个数据库变成我们现在正在处理的数据库;4、获取yyyy-md-dhh:mm:ss格式的每一行。如此就完成了在mongodb中存入日期。
MongoDB 正则表达式 正则表达式是使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。 许多程序设计语言都支持利用正则表达式进行字符串操作。 MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式。 MongoDB使用PCRE (Perl Compatible Regular Expression) 作为正则表达式语言。 不同于全文检索,我们使用正则表达式不需要做任何配置。 考虑以下 posts 集合..
mongodb创建账号密码的方法:先使用use命令选择一个数据库,然后使用db.createUser()方法即可创建用户名密码。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008