Mongoose查询Model.findOneAndUpdate()函数

Mongoose查询Model.findOneAndUpdate()函数

Mongoose API的 查询Model.findOneAndUpdate() 函数用于查找并更新具有“update”对象中提到的信息的现有文档。它只找到并更新在过滤器中返回的第一个文档。

语法:

Model.findOneAndUpdate(conditions, update, options, callback)
JavaScript

参数: 它接受以下4个参数,如上所述,并进行描述:

  • conditions: 它是一个 mongoose 对象,用于标识要更新的现有文档。
  • update: 它是一个 mongoose 对象,用于更新现有文档中的数据。
  • options: 它是一个可选的 mongoose 对象,派生自 Query.prototype.setOptions()。
  • callback: 它是一个回调函数,接受2个参数: error 和 res。

返回类型: 它以一个 Query 对象的形式返回。

设置 Node.js Mongoose 模块:

步骤1: 使用以下命令创建一个 Node.js 应用程序:

npm init
JavaScript

将下面的英文翻译成中文,不解释,保留HTML格式:

步骤2: 创建NodeJS应用程序后,使用以下命令安装所需的模块:

npm install mongoose
JavaScript

以下示例将演示 findOneAndUpdate() 方法

示例1 : 在此示例中,我们将使用该方法来查找并更新一个名为“Luffy”的现有文档。

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, 
        select: false
    }, 
    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.findOneAndUpdate( 
        { name: 'Luffy' },  
        { name: 'Shanks' } 
    ); 
})()
JavaScript

运行应用程序的步骤: 从项目的根目录运行以下命令来运行应用程序:

node main.js
JavaScript

输出:

Mongoose查询Model.findOneAndUpdate()函数

MongoDB Compass使用的数据库GUI表示:

Mongoose查询Model.findOneAndUpdate()函数

示例2: 在这个示例中,我们将使用这种方法来查找和更新一个已存在的年龄为“19”的文档。

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, 
        select: false
    }, 
    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.findOneAndUpdate({ age: 19 }, { age: 23 }); 
})()
JavaScript

运行应用程序的步骤 :从项目的根目录使用以下命令运行应用程序:

node main.js
JavaScript

输出:

Mongoose查询Model.findOneAndUpdate()函数

通过MongoDB Compass查看数据库的GUI表示:

Mongoose查询Model.findOneAndUpdate()函数

参考: https://mongoosejs.com/docs/api.html#model_Model-findOneAndUpdate

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程

登录

注册