当前位置: 移动技术网 > IT编程>开发语言>JavaScript > Node.js使用MongoDB的ObjectId作为查询条件的方法

Node.js使用MongoDB的ObjectId作为查询条件的方法

2019年09月14日  | 移动技术网IT编程  | 我要评论

当往mongodb中插入一条数据时,会自动生成objectid作为数据的主键。 那么如何通过objectid来做数据的唯一查询呢?

在mongodb中插入一条数据

在mongodb中插入一条如下结构的数据:

{
 _id: 5d6a32389c825e24106624e4,
 title: 'github 上有什么好玩的项目',
 content: '上个月有水友私信问我,github 上有没有比较好玩的项目可以推荐?我跟他说:"有,过两天我整理一下"。\n' +
  '\n' +
  '然而,一个月过去了,我把这件事情忘了精光,直至他昨天提醒我才记起2_05.png。\n',
 creation: 2019-08-31t08:39:20.384z
}

其中,上述_id的值“5d6a32389c825e24106624e4”,是mongodb自动分配的。

使用 mongodb 的 objectid 作为查询条件

须知,_id的值“5d6a32389c825e24106624e4”并非是字符串,而是objectid对象类型。因此,如下查询是行不通的:

// 查询指定文档
const findnews = function (db, newsid, callback) {
  // 获取集合
  const news = db.collection('news');

  // 查询指定文档
  news.findone({_id: newsid},function (err, result) {
    if (err) {
      console.error('error end: ' + err.stack);
      return;
    }
    
    console.log("查询指定文档,响应结果是:");
    console.log(result);
    callback(result);
  });
}

需将上述newsid转为 objectid对象类型。怎么做呢?做法参考如下:

const objectid = require('mongodb').objectid;

// 查询指定文档
const findnews = function (db, newsid, callback) {
  // 获取集合
  const news = db.collection('news');

  // 查询指定文档
  news.findone({_id: objectid(newsid)},function (err, result) {
    if (err) {
      console.error('error end: ' + err.stack);
      return;
    }
    
    console.log("查询指定文档,响应结果是:");
    console.log(result);
    callback(result);
  });
}

其中,require('mongodb').objectid用于获取objectid类,并将字符串newsid转为了 objectid 类型。

参考引用

完整源码:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网