Node.js 使用 MongoDB 的 ObjectId 做爲查詢條件

當往MongoDB中插入一條數據時,會自動生成ObjectId做爲數據的主鍵。 那麼如何經過ObjectId來作數據的惟一查詢呢?node

在MongoDB中插入一條數據

在MongoDB中插入一條以下結構的數據:git

{
  _id: 5d6a32389c825e24106624e4,
  title: 'GitHub 上有什麼好玩的項目',
  content: '上個月有水友私信問我,GitHub 上有沒有比較好玩的項目能夠推薦?我跟他說:"有,過兩天我整理一下"。\n' +
    '\n' +
    '然而,一個月過去了,我把這件事情忘了精光,直至他昨天提醒我才記起2_05.png。\n',
  creation: 2019-08-31T08:39:20.384Z
}

其中,上述_id的值「5d6a32389c825e24106624e4」,是MongoDB自動分配的。github

使用 MongoDB 的 ObjectId 做爲查詢條件

須知,_id的值「5d6a32389c825e24106624e4」並不是是字符串,而是ObjectId對象類型。所以,以下查詢是行不通的:mongodb

// 查詢指定文檔
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對象類型。怎麼作呢?作法參考以下:ui

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 類型。code

參考引用

相關文章
相關標籤/搜索