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


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


Mongoose 查詢 API update() 方法用於使用 MongoDB 查詢係統更新集合中的文檔。它可以一次更新一份或多份文檔。

用法:

Query.prototype.update(filter, doc, options, callback)

參數:它接受上麵提到的以下 4 個參數,如下所述:

  • filter:它是一個 Mongoose 對象,用於標識要更新的現有文檔。
  • doc:它是一個 mongoose 對象,它將更新現有文檔中的數據。
  • options:它是一個可選的 Mongoose 對象,派生自查詢.prototype.setOptions().
  • callback:它是一個回調函數,接受參數,錯誤,寫操作結果.

返回類型:它返回一個 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


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: 'Luffy', 
        age: 19 
    }, 
    { 
        name: 'Nami', 
        age: 30 
    }, 
    { 
        name: 'Zoro', 
        age: 35 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    await Person.insertMany(personsArray); 
    await Person.where({ name: 'Luffy' }).update({ age: 20 }); 
})()

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

node main.js

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

示例 2:在此示例中,我們將使用此方法來更新年齡為 “19” 的多個現有文檔。

文件名: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: 'Luffy', 
        age: 19 
    }, 
    { 
        name: 'Nami', 
        age: 19 
    }, 
    { 
        name: 'Zoro', 
        age: 35 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    await Person.insertMany(personsArray); 
    await Person.where({ age: 19 }).update({ age: 20 }); 
})()

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

node main.js

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

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



相關用法


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