Mongoose Query.prototype.set()函数
使用Mongoose Query API set()方法可以添加$set中间件来根据指定的路径和传入的值更新一个或多个MongoDB文档。
语法:
Query.prototype.set(path, val)
参数: 接受以上提及并以下述方式描述的以下参数:
- 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
// 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 Compass的数据库的图形用户界面表示:
示例2: 在这个示例中,我们将使用这个方法来更新名为“Luffy”的一条记录的年龄。
文件名: main.js
// 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 Compass中使用的数据库的GUI表示:
参考: https://mongoosejs.com/docs/api/query.html#query_Query-set