MongoDB【应用 01】通过_id获取记录创建时间(生成规则+解析步骤+源码分享)

通过_id获取记录创建时间

  • [1. _id的生成规则](#1. _id的生成规则)
  • [2. 步骤及举例](#2. 步骤及举例)
    • [2.1 步骤](#2.1 步骤)
    • [2.2 举例](#2.2 举例)

1. _id的生成规则

MongoDB 的 _id 值按照 ObjectId 的生成规则来生成。ObjectId是一个12字节(16进制表示为 24 位字符串)的标识符,它的构成包括以下几个部分:

  • 【4字节】时间戳(Timestamp) :前 4 个字节表示创建此 ObjectId 时的 Unix 时间戳(精确到秒)。这提供了秒级的时间唯一性。
  • 【3字节】机器标识符(Machine Identifier) :接下来的 3 个字节代表生成此 ObjectId 的机器的唯一标识符。通常,这基于主机名的散列值,确保在同一网络中的不同服务器上生成的 ObjectId 可以区分。
  • 【2字节】进程标识符(Process Identifier, PID) :接下来的 2 个字节表示生成此 ObjectId 的进程 ID。这样即使在同一台机器上运行的多个 MongoDB 实例或进程,也能确保它们生成的 ObjectId 是唯一的。
  • 【3字节】计数器(Counter) :最后的 3 个字节包含一个计数器,它在一个特定的秒内(即具有相同时间戳的部分)递增。这个计数器在每个新生成的 ObjectId 中增加,确保即使在同一秒内,在同一台机器上的同一个进程中创建的多个 ObjectId 也是唯一的。

2. 步骤及举例

2.1 步骤

通过_id获取到创建时间的步骤为:

  1. 查询文档: 首先,查询目标文档的_id字段值。
  2. 提取前8位十六进制字符: 从ObjectId对象中提取前8位(4个十六进制字符)。
  3. 转换为十进制数: 使用适当的函数或方法将这4个十六进制字符转换为10进制数。
  4. 格式化成时间:使用函数将毫秒值转换为时间格式。

2.2 举例

以下是一条记录,_id是数据库生成的,createTime是后天的当前时间:

_id createTime
66160a7c519bf4573a3bd5a6 2024-04-08 11:41:48

以下为Java代码:

java 复制代码
public static void main(String[] args) {
    // 1. 目标_id字段值
    String _id = "66160a7c519bf4573a3bd5a6";
    // 2. 提取前8位十六进制字符
    String timestampStr = _id.substring(0, 8);
    // 3. 转换为10进制数
    long timestampInSeconds = Long.parseLong(timestampStr, 16);
    // 4. 格式化成时间
    // 将时间戳转换为毫秒
    long timestampInMillis = timestampInSeconds * 1000;
    // 使用时间戳创建一个Instant对象
    Instant instant = Instant.ofEpochMilli(timestampInMillis);
    // 创建DateTimeFormatter对象并设置格式模式
    DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
    // 将Instant对象转换为LocalDateTime,并在指定时区下格式化为字符串
    String formattedDateTime = instant.atZone(ZoneId.systemDefault()).format(formatter);
    // 输出结果
    System.out.println("Formatted date and time: " + formattedDateTime);
}

执行结果:

bash 复制代码
Formatted date and time: 2024-04-10 11:41:48
相关推荐
HackTwoHub7 分钟前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t13 分钟前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK22 分钟前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)1 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
S1998_1997111609•X2 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
KmSH8umpK3 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
BU摆烂会噶4 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
l1t5 小时前
DeepSeek总结的DuckLake 入门
数据库
Joseph Cooper5 小时前
RAG 与 AI Agent:智能体真的需要检索增强生成吗?
数据库·人工智能·ai·agent·rag·上下文工程
light blue bird5 小时前
主子端台二分法任务汇总组件
前端·数据库·.net·桌面端winform