當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Mongoose Query prototype.transform()用法及代碼示例


Mongoose 是針對 node.js 環境的 MongoDB 對象建模和處理。 Mongoose Query transform() 方法用於轉換從 mongoose 查詢響應返回的文檔。當我們需要向加載的文檔添加新屬性時,轉換可能很有用。讓我們通過一些例子來更多地了解這一點。

用法

Query.prototype.transform()

Parameters: 它接受一個參數:如下所述:

  • fn:它是一個運行時轉換查詢結果的函數

返回類型:它返回查詢對象。

創建節點應用程序並安裝 Mongoose:

步驟1:使用以下命令創建節點應用程序:

mkdir folder_name
cd folder_name
npm init -y
touch main.js

步驟 2:創建 ReactJS 應用程序後,使用以下命令安裝所需的模塊:

npm install mongoose

項目結構: 它將如下所示。

使用 MongoDB 指南針的數據庫的 GUI 表示:目前,該館藏沒有任何數據。

示例 1:在此示例中,我們將使用查詢 API transform() 方法將當前日期設置為返回的文檔。

文件名:main.js

Javascript


const mongoose = require('mongoose') 
  
// Database connection 
mongoose.connect('mongodb://localhost:27017/query-helpers', { 
    dbName: 'event_db', 
    useNewUrlParser: true, 
    useUnifiedTopology: true
}, err => err ? console.log(err) :  
    console.log('Connected to database')); 
  
const personSchema = new mongoose.Schema({ 
    name: { 
        type: String, 
    }, 
    age: { 
        type: Number, 
    } 
}); 
  
const personsArray = [ 
    { 
        name: 'John', 
        age: 22 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    await Person.insertMany(personsArray); 
  
    const persons = await Person.find().transform(per => { 
        return { 
            ...per, 
            currentDate: new Date() 
        } 
    }) 
  
    console.log(persons); 
})()

運行應用程序的步驟:從項目的根目錄使用以下命令運行應用程序:

node main.js

輸出:我們看到結果中的值保持不變。

使用 MongoDB Compass 的數據庫的 GUI 表示:

示例 2:在此示例中,我們將使用查詢 API transform() 方法來設置返回文檔的計數。

文件名:main.js

Javascript


const mongoose = require('mongoose') 
  
// Database connection 
mongoose.connect('mongodb://localhost:27017/query-helpers', { 
    dbName: 'event_db', 
    useNewUrlParser: true, 
    useUnifiedTopology: true
}, err => err ? console.log(err) :  
    console.log('Connected to database')); 
  
const personSchema = new mongoose.Schema({ 
    name: { 
        type: String, 
    }, 
    age: { 
        type: Number, 
    } 
}); 
  
const personsArray = [ 
    { 
        name: 'John', 
        age: 22 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    await Person.insertMany(personsArray); 
    const persons = await Person.find().transform(per => { 
        return { 
            ...per, 
            count: per.length 
        } 
    }) 
  
    console.log(persons); 
})()

運行應用程序的步驟:從項目的根目錄使用以下命令運行應用程序:

node main.js

輸出:我們看到結果中的值保持不變。

使用 MongoDB 指南針的數據庫的 GUI 表示:

參考: https://mongoosejs.com/docs/api/query.html#query_Query-transform



相關用法


注:本文由純淨天空篩選整理自dishebhbhayana大神的英文原創作品 Mongoose Query prototype.transform() API。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。