当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Mongoose Query.prototype.replaceOne()用法及代码示例


Mongoose 查询 API replaceOne() 方法用于使用 MongoDB 查询系统替换集合中的单个文档。它一次只能更新一份文档。

用法:

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

参数:它接受上面提到的以下 4 个参数,如下所述:

  • filter: 它是一个 Mongoose 对象,用于标识要替换的现有文档。
  • doc:它是一个 mongoose 对象,它将替换现有文档。
  • options:它是一个可选的 Mongoose 对象,派生自查询.prototype.setOptions().
  • callback:它是一个回调函数,接受2个参数,错误写操作结果.

返回类型:它返回一个 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: 20, 
    }, 
    { 
        name: 'Zoro', 
        age: 35 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    await Person.insertMany(personsArray); 
    await Person.where({ name: 'Luffy' }) 
            .replaceOne({ age: 21 }); 
})()

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

node main.js

输出:使用 MongoDB 指南针的数据库的 GUI 表示:

示例 2:在此示例中,我们将使用此方法替换年龄大于或等于“18”的单个文档。

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

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

node main.js

输出:使用 MongoDB 指南针的数据库的 GUI 表示:

参考: https://mongoosejs.com/docs/api/query.html#query_Query-replaceOne



相关用法


注:本文由纯净天空筛选整理自dishebhbhayana大神的英文原创作品 Mongoose Query.prototype.replaceOne() API。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。