新闻中心

Mongoose中将_id字段设置为数字类型并实现自动递增序列号

2025-11-12
浏览次数:
返回列表

mongoose中将_id字段设置为数字类型并实现自动递增序列号

本教程详细阐述如何在Mongoose中自定义_id字段的数据类型为数字,而非默认的ObjectId。我们将通过创建自定义SchemaType来强制_id为正整数,并进一步介绍如何结合Mongoose的生命周期钩子和独立的计数器集合,为数字_id字段实现可靠的自动递增序列号生成机制,确保数据一致性和唯一性。

1. 理解Mongoose的_id字段与默认行为

在Mongoose中,每个文档默认都会有一个名为_id的特殊字段,它作为文档的唯一标识符。Mongoose默认将_id字段的数据类型设置为ObjectId,这是一种12字节的BSON类型,由MongoDB自动生成,能够保证在分布式环境下的唯一性。

当尝试将_id直接设置为Number类型时,例如:

const mySchema = new mongoose.Schema({
  _id: Number
});

这种做法并不能让MongoDB自动生成递增的数字_id。实际上,如果我们在创建文档时不手动指定_id,Mongoose仍然会为其生成一个ObjectId。如果手动指定一个数字,例如_id: 1,则可以正常保存。但是,要实现自动递增的序列号,我们需要更复杂的机制。

Tanka Tanka

具备AI长期记忆的下一代团队协作沟通工具

Tanka 146 查看详情 Tanka

2. 自定义_id为数字类型:NumberId SchemaType

为了确保_id字段严格为数字类型,并且可以施加额外的验证(例如必须是正整数),我们可以创建一个自定义的Mongoose SchemaType。这比简单地将类型设为Number更强大和灵活。

2.1 创建自定义SchemaType

我们将创建一个名为NumberId的自定义SchemaType,它继承自mongoose.SchemaType,并实现其cast方法来验证输入值。

const mongoose = require('mongoose');

/**
 * 自定义SchemaType:NumberId
 * 用于确保_id字段为正整数。
 */
function NumberId(key, options) {
  // 调用父类构造函数,并指定自定义类型名称
  mongoose.SchemaType.call(this, key, options, 'NumberId');
}

// 继承自 mongoose.SchemaType
NumberId.prototype = Object.create(mongoose.SchemaType.prototype);

// 实现 cast() 方法进行类型转换和验证
NumberId.prototype.cast = function (val) {
  if (typeof val !== 'number') {
    throw new Error('NumberId: ' + val + ' 不是一个数字。');
  }
  if (val % 1 !== 0) {
    throw new Error('NumberId: ' + val + ' 不是一个整数。');
  }
  if (val < 0) {
    throw new Error('NumberId: ' + val + ' 是一个负数。');
  }
  return val;
};

// 注册新的SchemaType
mongoose.Schema.Types.NumberId = NumberId;

在上面的代码中:

  • 我们定义了一个NumberId函数,它作为我们自定义SchemaType的构造函数。
  • 通过Object.create(mongoose.SchemaType.prototype),NumberId继承了Mongoose SchemaType的所有基本功能。
  • cast方法是核心,它负责将输入值转换为期望的类型,并在转换过程中进行验证。如果值不符合要求,它会抛出错误。
  • 最后,通过mongoose.Schema.Types.NumberId = NumberId;将这个自定义类型注册到M

以上就是Mongoose中将_id字段设置为数字类型并实现自动递增序列号的详细内容,更多请关注其它相关文章!


# 设为  # 洛川网站建设推广公司  # 阿尔曼集团的seo  # 陕西网站建设较好的公司  # 侯马商城网站建设价格  # 北京网站优化推广收集  # joo yeon seo韩国女星  # 湖南品牌网站建设技术  # 优化美食网站的方案  # 乐天seo  # 肇庆网站建设在线推广  # 并在  # go  # 是一个  # 后端  # 自动生成  # 创建一个  # 正整数  # 文档  # 设置为  # 自定义  # 字节  # mongodb 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: sublime怎么预览Markdown渲染效果_Markdown Preview插件 for sublime教程  《刺客信条:影》PS5 Pro和Switch 2画面对比  vivo云服务网页版登录 怎么登录vivo云服务网页版  如何在复杂的电商平台中优雅地管理共享资源并确保正确重定向,使用spryker-shop/resource-share-page模块助你一臂之力  Windows 11怎么彻底关闭定位_Windows 11服务中禁用Geolocation  MAC怎么安装Homebrew包管理器_MAC为开发者和高级用户安装命令行工具  Go语言JSON解析深度指南:动态访问与结构体映射实践  CSS条件样式无法按设备触发怎么排查_media条件语句正确设置解决触发问题  在Go开发中优雅管理ListenAndServe进程:GoSublime集成方案  一加 14R 快充无反应_一加 14R 充电优化  海棠电脑版入口_通过电脑访问海棠官网阅读  解决 MongoDB 聚合查询中对象数组 _id 匹配问题  小米14应用无法联网原因分析_小米14网络权限修复  在命令行怎么运行html项目_命令行运行html项目方法【教程】  微信群消息显示延迟如何解决 微信群消息刷新优化方法  钉钉视频会议声音异常如何处理 钉钉会议音频修复技巧  TikTok网页版直接登录 TikTok网页端官方平台入口  魅族20怎样在浏览器开无图省流_iPhone魅族20浏览器开无图省流【流量节省】  win11 Snap Layouts怎么用 Win11窗口布局与分屏多任务高效指南【必学】  拷贝漫画电脑版官网入口 拷贝漫画(PC版)在线直达  优化Django表单:提交验证失败后保留用户输入  Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】  邮政快递包裹最新位置 邮政快递实时追踪入口  蛙漫2日版入口 WAMAN2(日版)无删减漫画官网链接  Win11文件资源管理器卡顿怎么修 Win11重置资源管理器进程优化响应速度【修复方法】  Win10怎么设置静态IP地址 Win10手动配置IP地址步骤【指南】  css链接悬停下划线样式如何自定义_使用::after结合content和transition  c++中为什么推荐使用using替代typedef_c++现代化类型别名  铃兰之剑为这和平的世界希里技能组及加点推荐  cad如何更改注释性对象的比例_cad注释性比例调整方法  如何在J*a中使用Locale处理多语言环境  Win11怎么开启省电模式_Win11电池节电模式自动开启  qq邮箱发邮件给国外发不出去_QQ邮箱国际邮件发送失败原因与解决  C++如何操作注册表_Windows平台下C++读写注册表的API函数详解  如何更改在 Excel 中打开超链接时的默认浏览器  汽水音乐在线版入口_汽水音乐网页播放手册  TypeScript/J*aScript:高效查找数组中首个唯一ID对象  c++20的std::jthread是什么_c++可中断线程与RAII式管理  NRF24L01数据传输深度解析:解决大载荷接收异常与分包策略  必由学官网首页入口 必由学教师网页版登录指南  Yandex搜索引擎官方地址 俄罗斯网络世界的主要入口  PyTorch模型训练准确率不提升:诊断与修复常见指标计算错误  单12V-2&#215;6实现为RTX 5090供电750W!甚至都没敢跑分  如何设置Windows Defender的定时扫描_计划任务实现自动杀毒【安全】  QQ邮箱电脑版登录入口_QQ邮箱官方网站登录平台  Golang如何通过reflect操作map_Golang reflect map操作与遍历技巧  Python getattr() 异常处理深度解析:避免程序意外退出  微博网页版官方账号登录 微博网页版内容浏览使用指南  J*a如何使用AtomicInteger控制计数_J*a无锁计数器性能分析  J*a递归快速排序中静态变量导致数据累积问题的解决方案 

搜索