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

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6


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

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: go

“Node.js 使用 MongoDB 的 ObjectId 作为查询条件” 的相关文章