Node.js使用MongoDB的ObjectId作为查询条件的方法
程序员文章站
2022-05-25 10:58:16
当往mongodb中插入一条数据时,会自动生成objectid作为数据的主键。 那么如何通过objectid来做数据的唯一查询呢?
在mongodb中插入一条数据...
当往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 类型。
参考引用
完整源码:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 李隆基弄死杨贵妃后晚年是怎么度过 他过的到底有多惨呢
下一篇: 以微博做为营销平台的微博营销好做吗
推荐阅读
-
Node.js对MongoDB数据库实现模糊查询的方法
-
使用Easyui实现查询条件的后端传递并自动刷新表格的两种方法
-
Node.js使用MongoDB的ObjectId作为查询条件的方法
-
Node.js中使用mongoose操作mongodb数据库的方法
-
使用aggregate在MongoDB中查询重复数据记录的方法
-
分页查询关键代码 多条件查询关键代码 删除选中商品关键代码 修改要先回显再修改 修改要先回显再修改 同一业务集中使用同一servlet的方法
-
将MongoDB作为Redis式的内存数据库的使用方法
-
MySQL中使用case when 语句实现多条件查询的方法_MySQL
-
使用Easyui实现查询条件的后端传递并自动刷新表格的两种方法
-
Node.js使用MongoDB的ObjectId作为查询条件的方法