Node.js使用MongoDB的ObjectId作為查詢條件的方法
當往MongoDB中插入一條數(shù)據(jù)時,會自動生成ObjectId作為數(shù)據(jù)的主鍵。 那么如何通過ObjectId來做數(shù)據(jù)的唯一查詢呢?
在MongoDB中插入一條數(shù)據(jù)
在MongoDB中插入一條如下結構的數(shù)據(jù):
{ _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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
使用Node.js實現(xiàn)一個簡單的FastCGI服務器實例
這篇文章主要介紹了使用Node.js實現(xiàn)一個簡單的FastCGI服務器實例,也可以作為一個比較詳細的Node.js服務器創(chuàng)建教程,需要的朋友可以參考下2014-06-06node+express框架中連接使用mysql(經(jīng)驗總結)
這篇文章主要介紹了node+express框架中連接使用mysql(經(jīng)驗總結),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11