您好,登錄后才能下訂單哦!
當往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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。