Node.js使用MongoDB的ObjectId作為查詢條件的方法
當(dāng)往MongoDB中插入一條數(shù)據(jù)時(shí),會(huì)自動(dòng)生成ObjectId作為數(shù)據(jù)的主鍵。 那么如何通過ObjectId來做數(shù)據(jù)的唯一查詢呢?
在MongoDB中插入一條數(shù)據(jù)
在MongoDB中插入一條如下結(jié)構(gòu)的數(shù)據(jù):
{ _id: 5d6a32389c825e24106624e4, title: 'GitHub 上有什么好玩的項(xiàng)目', content: '上個(gè)月有水友私信問我,GitHub 上有沒有比較好玩的項(xiàng)目可以推薦?我跟他說:"有,過兩天我整理一下"。\n' + '\n' + '然而,一個(gè)月過去了,我把這件事情忘了精光,直至他昨天提醒我才記起2_05.png。\n', creation: 2019-08-31T08:39:20.384Z }
其中,上述_id的值“5d6a32389c825e24106624e4”,是MongoDB自動(dòng)分配的。
使用 MongoDB 的 ObjectId 作為查詢條件
須知,_id的值“5d6a32389c825e24106624e4”并非是字符串,而是ObjectId對(duì)象類型。因此,如下查詢是行不通的:
// 查詢指定文檔 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("查詢指定文檔,響應(yīng)結(jié)果是:"); console.log(result); callback(result); }); }
需將上述newsId轉(zhuǎn)為 ObjectId對(duì)象類型。怎么做呢?做法參考如下:
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("查詢指定文檔,響應(yīng)結(jié)果是:"); console.log(result); callback(result); }); }
其中,require('mongodb').ObjectId用于獲取ObjectId類,并將字符串newsId轉(zhuǎn)為了 ObjectId 類型。
參考引用
完整源碼:https://github.com/waylau/mean-book-samples
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用Node.js實(shí)現(xiàn)一個(gè)簡單的FastCGI服務(wù)器實(shí)例
這篇文章主要介紹了使用Node.js實(shí)現(xiàn)一個(gè)簡單的FastCGI服務(wù)器實(shí)例,也可以作為一個(gè)比較詳細(xì)的Node.js服務(wù)器創(chuàng)建教程,需要的朋友可以參考下2014-06-06Node.js中Sequelize?hook的使用方法小結(jié)
Sequelize?提供了多個(gè)?hook,用于在執(zhí)行數(shù)據(jù)庫操作時(shí)執(zhí)行一些自定義邏輯,本文為大家整理了一些常用的?Sequelize?hook?列表及其作用,希望對(duì)大家有所幫助2024-02-02node+express框架中連接使用mysql(經(jīng)驗(yàn)總結(jié))
這篇文章主要介紹了node+express框架中連接使用mysql(經(jīng)驗(yàn)總結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11package.json的版本號(hào)更新優(yōu)化方法
這篇文章主要為大家介紹了package.json的版本號(hào)更新優(yōu)化方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04