ObjectId

MongoDB每个集合存储的每个文档必须有一个"_id"键,默认是个ObjectId对象。

"_id"作为当前文档在集合的唯一标识。

71standby:PRIMARY> db.accesslog.find({},{_id:1}).pretty()
{ "_id" : ObjectId("5d1d7225d06339b452d964f6") }
{ "_id" : ObjectId("5d1d7225d06339b452d964f7") }
{ "_id" : ObjectId("5d1d7225d06339b452d964f8") }
{ "_id" : ObjectId("5d1d7226d06339b452d964fa") }
{ "_id" : ObjectId("5d1d7226d06339b452d964fb") }
{ "_id" : ObjectId("5d1d7226d06339b452d964fc") }
{ "_id" : ObjectId("5d1d72acd06339b452d964fe") }
{ "_id" : ObjectId("5d1d72acd06339b452d964ff") }
{ "_id" : ObjectId("5d1d72acd06339b452d96500") }
71standby:PRIMARY>

ObjectId是有12字节组成的,其前面4字节表示的是文档创建的时间戳(比北京时间晚了 8 个小时)

在 mongo shell 里可以通过 ObjectId.getTimestamp() 来查看文档创建时间。

71standby:PRIMARY> x = ObjectId()
ObjectId("5d9ea85b7444a82a869f958f")
71standby:PRIMARY> x
ObjectId("5d9ea85b7444a82a869f958f")
71standby:PRIMARY> x.getTimestamp()
ISODate("2019-10-10T03:41:15Z")
tvos-mediacenter-rs1:PRIMARY>

时间转换

以 "5d9ea85b7444a82a869f958f" 为例:

# 1字节等于8bit,而一个十六进制数可以由4bit表示,所以两个十六进制数可以表示一个字节

# 所以前4个字节则是前面8个16进制数。

In [25]: import time                                                                                                                                                                                                                      

In [26]: key = '5d9ea85b7444a82a869f958f'                                                                                                                                                                                                 

In [27]: ts = int(key[:8],16)       # 16进制转10进制                                                                                                                                                                                                      

In [28]: ts
Out[28]: 1570678875 In [29]: time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(ts))
Out[29]: '2019-10-10 11:41:15' # 比UTC时间早8个小时 In [30]: hex(ts) # 10进制转16进制
Out[30]: '0x5d9ea85b' In [31]: In [32]: 11*16**0 + 5*16**1 + 8*16**2 + 10*16**3 + 14*16**4 + 9*16**5 + 13*16**6 + 5*16**7
Out[32]: 1570678875 In [33]:

Convert BSON to JSON

In [13]: doc
Out[13]:
{'_id': ObjectId('54d9a762ab4f16f448312863'),
'artist': '后街男孩',
'cover': 'http://img5.douban.com/lpic/s2512539.jpg',
'song': 'Everbody'} In [14]: import json In [15]: from bson.json_util import dumps In [16]: dumps(doc)
Out[16]: '{"_id": {"$oid": "54d9a762ab4f16f448312863"}, "artist": "\\u540e\\u8857\\u7537\\u5b69", "cover": "http://img5.douban.com/lpic/s2512539.jpg", "song": "Everbody"}' In [17]: json.loads(dumps(doc))
Out[17]:
{'_id': {'$oid': '54d9a762ab4f16f448312863'},
'artist': '后街男孩',
'cover': 'http://img5.douban.com/lpic/s2512539.jpg',
'song': 'Everbody'} In [18]:

ObjectId初探的更多相关文章

  1. zabbix报警逻辑初探

    zabbix报警逻辑初探 首先贴出一张网上找的一张关于zabbix报警相关表结构及表关联逻辑图: actions表 actions表对应前端配置是动作(actions) action由conditio ...

  2. 初探领域驱动设计(2)Repository在DDD中的应用

    概述 上一篇我们算是粗略的介绍了一下DDD,我们提到了实体.值类型和领域服务,也稍微讲到了DDD中的分层结构.但这只能算是一个很简单的介绍,并且我们在上篇的末尾还留下了一些问题,其中大家讨论比较多的, ...

  3. MongoDB数据实体中的ObjectId序列化成json的一个小坑

    很多时候我们都需要对实体对象进行序列化与反序列化,而ObjectId类型,只能用mongo的驱动以bson格式来序列化,但我们对外的交互,一般是json格式. 有两种解决方案: 1.自己写一个json ...

  4. CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探

    CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码 ...

  5. 从273二手车的M站点初探js模块化编程

    前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...

  6. JavaScript学习(一) —— 环境搭建与JavaScript初探

    1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...

  7. .NET文件并发与RabbitMQ(初探RabbitMQ)

    本文版权归博客园和作者吴双本人共同所有.欢迎转载,转载和爬虫请注明原文地址:http://www.cnblogs.com/tdws/p/5860668.html 想必MQ这两个字母对于各位前辈们和老司 ...

  8. React Native初探

    前言 很久之前就想研究React Native了,但是一直没有落地的机会,我一直认为一个技术要有落地的场景才有研究的意义,刚好最近迎来了新的APP,在可控的范围内,我们可以在上面做任何想做的事情. P ...

  9. iOS CoreData 中 objectID 的不变性

    关于 CoreData的 objectID 官方文档有这样的表述:新建的Object还没保存到持久化存储上,那么它的objectID是临时id,而保存之后,就是持久化的id,不会再变化了. 那么,我想 ...

随机推荐

  1. sklearn--模型的评价

    sklearn.metrics 1.MSE(均方误差)和RMSE(均方根误差),以及score() lr.score(test_x,test_y)#越接近1越好,负的很差 from sklearn.m ...

  2. Linux 下升级Android Studio失败

    在Linux下进行升级的时候,会弹出一个窗口,有一个表格,从表中发现在进行某些更新某些包是没有权限,解决方法很简单,将Android Studio安装文件夹改成当前Linux登陆用户即可. 1.找到A ...

  3. config.json读取和存储

    json格式的配置文件的读取和存储 public class ConfigHelper { public static T GetConfig<T>(string path) { if ( ...

  4. python_tkinter组件摆放方式

    1.最小界面组成 # 导入tkinter模块 import tkinter # 创建主窗口对象 root = tkinter.Tk() # 设置窗口大小(最小值:像素) root.minsize(30 ...

  5. [唐胡璐]Selenium技巧- IEDriverServer在进程中没有关闭?

    有时候跑完脚本后,IEDriverServer.exe进程没杀掉。 解决方法: 在关闭driver时用Driver.Quit();不要用Driver.Close();Driver.Quit() Qui ...

  6. Python模块之目录

     1.加密算法有关 hmac模块 hashlib模块 2.进程有关 multiprocessing模块 3.线程有关 threading模块 4.协程有关 asyncio模块 5.系统命令调用 sub ...

  7. CentOS 7 yum update 升级提示:PackageKit 锁定解决方案

    CentOS 7 系列新安装后都会进行yum update操作,但每次都会遇到PackageKit 锁定问题,提示如下: /var/run/yum.pid 已被锁定,PID 为 2694 的另一个程序 ...

  8. .net core 自动注入。。。。懵逼。。

    using Microsoft.AspNetCore.Http; using System.Globalization; using System.Threading.Tasks; namespace ...

  9. 题解 BZOJ1026 & luogu P2657 [SCOI2009]windy数 数位DP

    BZOJ & luogu 看到某大佬AC,本蒟蒻也决定学习一下玄学的数位$dp$ (以上是今年3月写的话(叫我鸽神$qwq$)) 思路:数位$DP$ 提交:2次 题解:(见代码) #inclu ...

  10. PHP mysqli_field_count() 函数

    定义和用法 mysqli_field_count() 函数返回最近查询的列数. 假设我们有一个 "websites" 表,其中有 5 个字段 20 行记录.返回最近查询的列数: & ...