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


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


Mongoose API 的 Mongoose Query API.prototype.setUpdate() 方法用於查詢對象。它允許我們使用新值和表達式設置當前更新操作。使用此方法我們可以修改更新查詢表達式。讓我們通過一個例子來理解setUpdate()方法。

用法:

query.setUpdate( object );

Parameters: 該方法接受單個參數,如下所述:

  • object:用於以對象的形式指定更新查詢表達式。

返回值:此方法返回未定義或不返回任何內容。

設置 Node.js 應用程序:

步驟 1:使用以下命令創建 Node.js 應用程序:

npm init

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

npm install mongoose

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

數據庫結構:數據庫結構如下所示,集合中存在以下文檔。

示例 1:在此示例中,我們將說明以下函數setUpdate()方法。我們正在更新訂單號集合中文檔之一的字段。使用setUpdate()方法我們正在更改查詢表達式並更新值。

文件名:app.js

Javascript


// Require mongoose module 
const mongoose = require("mongoose"); 
  
// Set Up the Database connection 
const URI = "mongodb://localhost:27017/geeksforgeeks"; 
  
const connectionObject = mongoose.createConnection(URI, { 
    useNewUrlParser: true, 
    useUnifiedTopology: true, 
}); 
  
const Customer = connectionObject.model( 
    "Customer", 
    new mongoose.Schema({ 
        name: String, 
        address: String, 
        orderNumber: Number, 
    }) 
); 
  
const query = Customer.find({ name: "Bhavesh" }); 
query.update({}, { $set: { orderNumber: 6 } }) 
query.setUpdate({ $set: { orderNumber: 0 } }) 
console.log(query.getUpdate()); 
query.exec((error, result) => { 
    if (error) { 
        console.log("Error -", error); 
    } else { 
        console.log("Result -", result); 
    } 
})

運行程序的步驟:要運行應用程序,請從項目的根目錄執行以下命令:

node app.js

輸出:

{ '$set': { orderNumber: 0 } }
Result - {
  acknowledged: true,
  modifiedCount: 1,
  upsertedId: null,
  upsertedCount: 0,

使用 Robo3T GUI 工具的數據庫的 GUI 表示:

示例 2:在此示例中,我們將說明以下函數setUpdate()方法。我們正在更新訂單號集合中文檔之一的字段。使用setUpdate()方法改變了我們正在更新的字段update()方法。最後,我們隻更新一個字段,即訂單號。

文件名:app.js

Javascript


// Require mongoose module 
const mongoose = require("mongoose"); 
  
// Set Up the Database connection 
const URI = "mongodb://localhost:27017/geeksforgeeks"; 
  
const connectionObject = mongoose.createConnection(URI, { 
    useNewUrlParser: true, 
    useUnifiedTopology: true, 
}); 
  
const Customer = connectionObject.model( 
    "Customer", 
    new mongoose.Schema({ 
        name: String, 
        address: String, 
        orderNumber: Number, 
    }) 
); 
  
const query = Customer.find({ name: "Aditya" }); 
query.update({}, { $set: { name: "Aaditya" } }) 
query.setUpdate({ $set: { orderNumber: 20 } }) 
console.log(query.getUpdate()); 
query.then((result) => { 
    console.log("Result -", result); 
}).catch((err) => { 
    console.log(err); 
})

運行程序的步驟:要運行應用程序,請從項目的根目錄執行以下命令:

node app.js

輸出:

{ '$set': { orderNumber: 20 } }

Result - {
  acknowledged: true,
  modifiedCount: 1,  
  upsertedId: null,  
  upsertedCount: 0,  
  matchedCount: 1    
}

使用 Robo3T GUI 工具的數據庫的 GUI 表示:

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



相關用法


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