nodejs判断MongoDB集合_id的类型

背景:

  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类型。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值