當往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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網之家。
新聞熱點
疑難解答
圖片精選