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


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


Mongoose 查詢 API set()方法用於添加一個$設置中間件,可根據指定的路徑和參數中傳遞的值幫助更新一個或多個 MongoDB 文檔。

用法:

Query.prototype.set(path, val)

Parameters: 它接受如上所述和如下所述的以下參數:

  • path:它是一個字符串,標識 Mongoose 模式中的路徑
  • val:它是在指定路徑上設置的值

返回類型:它返回一個 Query 對象作為響應。

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

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

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

步驟2:完成Node.js應用程序後,使用以下命令安裝所需的模塊

npm install mongoose

示例 1:在本例中,我們將使用此方法來更新一條名為“Luffy”的記錄的名稱。

文件名:main.js

Javascript


// Importing the module
const mongoose = require('mongoose')
// Creating the 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'));
let personSchema = new mongoose.Schema({
    name: {
        type: String,
    },
    age: {
        type: Number,
    }
});
let personsArray = [
    {
        name: 'Luffy',
        age: 20
    },
    {
        name: 'Nami',
        age: 20,
    },
    {
        name: 'Zoro',
        age: 35
    }
]
let Person = mongoose.model('Person', personSchema);
(async () => {
    await Person.insertMany(personsArray)
    let res = await Person.updateOne({ name: 'Luffy' }).
        set({ name: 'Usorp' })
    console.log({ res });
})();

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

node main.js

輸出:

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

示例 2:在本例中,我們將使用此方法來更新一條名為“Luffy”的記錄的年齡

文件名:main.js

Javascript


// Importing the module
const mongoose = require('mongoose')
// Creating the 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'));
let personSchema = new mongoose.Schema({
    name: {
        type: String,
    },
    age: {
        type: Number,
    }
});
let personsArray = [
    {
        name: 'Luffy',
        age: 20
    },
    {
        name: 'Nami',
        age: 20,
    },
    {
        name: 'Zoro',
        age: 35
    }
]
let Person = mongoose.model('Person', personSchema);
(async () => {
    await Person.insertMany(personsArray)
    let res = await Person.updateOne({ name: 'Luffy' }).
        set({ age: 19 })
    console.log({ res });
})();

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

node main.js

輸出

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

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



相關用法


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