nodejs判断MongoDB集合_id的类型
创始人
2024-06-03 02:05:45
0

背景:

  1. 在MongoDB中,_id字段是表示一个集合的主键,可以唯一标识每个文档。

  1. 使用默认的_id:默认情况下,在集合中插入文档时,如果字段名中没有_id的字段名称,则MongoDB将自动添加一个ObjectId字段。

  1. 自定义_id字段:当我们向一个集合中添加文档显示的创建“_id”字段时,MongoDB就不会默认生成_id字段,而是使用我们指定的"_id"字段。

  1. 我们在使用MongoDB的时候,采用了上面两种生成_id的方式,对于需要使用唯一ID的文档,我们就自己生成,否则我们就使用MongoDB自动生成的_id。

遇到的问题:

  1. 因为我们的_id有两种生成方式,在使用nodejs操作MongoDB的时候,删除和更新的时候因为_id字段类型的问题导致无法更新和删除

  1. 如果集合使用了MongoDB自动生成的_id,在操作的时候,必须这样写:{_id: new ObjectID(_id)}

怎么区分_id字段的类型呢?

  1. 我们自己生成的_id是字符串类型的,而MongoDB自动生成的_id是ObjectID类型的,怎么判断_id的类型呢?

2. 本来想通过MongoDB的集合api来判断_id的类型,找了半天还是没有找到对应的api(如果你知道,请告诉我,谢谢)

3. 既然集合上没有相应的api,那么只能通过查询结果来判断_id的类型了,下面是我的判断逻辑:

  var url = 'mongodb://' + username + ':' + password+'@' + ip + ":"+port + "/" + dbName;let client = new MongoClient(url);await client.connect();let db = client.db(dbName);let collection = db.collection(collectionName);let data = await collection.find(JSON.parse(filter)).sort(JSON.parse(sort)).limit(limit).skip(skip).toArray();let result = new Object();result.isObjectId = false;if (data.length !== 0) {if ('[object Object]' === Object.prototype.toString.call(data[0]._id)) {result.isObjectId = true;}}result.data = data;return result;
  1. 更新文档:

  var url = 'mongodb://' + username + ':' + password+'@' + ip + ":"+port + "/" + dbName;let client = new MongoClient(url);await client.connect();let db = client.db(dbName);let collection = db.collection(collectionName);if (isObjectId) {return collection.replaceOne({_id: new ObjectID(filter)}, doc);} return collection.replaceOne({_id: filter}, doc);
  1. 删除文档:

  var url = 'mongodb://' + username + ':' + password+'@' + ip + ":"+port + "/" + dbName;let client = new MongoClient(url);await client.connect();let db = client.db(dbName);let collection = db.collection(collectionName);if (isObjectId) {return collection.deleteOne({_id: new ObjectID(filter)}); }return collection.deleteOne({_id: filter}); 

总结:

记录当前查询出来的每个文档_id的类型,然后在更新的时候根据_id的类型来生成对应的_id类型。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...