溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Node.js使用MongoDB的ObjectId作為查詢條件的方法

發(fā)布時(shí)間:2020-10-11 20:19:20 來源:腳本之家 閱讀:277 作者:waylau 欄目:web開發(fā)

當(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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI