相思资源网 Design By www.200059.com
当往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 类型。
参考引用
完整源码:https://github.com/waylau/mean-book-samples
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无Node.js使用MongoDB的ObjectId作为查询条件的方法的评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。