Mongoose Query.prototype.setQuery()方法
Mongoose的Query API.prototype.setQuery()方法用于Query对象。它允许我们设置和配置查询对象以返回JSON对象。该方法接受查询条件对象作为参数。让我们通过一个示例来理解setQuery()方法。
语法:
query.setQuery( object );
参数: 此方法接受一个参数,如下所述:
- object: 用于指定查询条件对象。
返回值: 此方法不返回任何值。
设置Node.js Mongoose模块:
步骤1: 使用以下命令创建一个Node.js应用程序:
npm init
步骤2: 创建NodeJS应用后,使用以下命令安装所需模块:
npm install mongoose
项目结构: 项目的结构将如下所示:
数据库结构: 数据库结构将如下所示,在MongoDB中存在以下数据库。
示例1: 下面的示例说明了Mongoose连接 setQuery() 方法的基本功能。在这个示例中,我们定义了一个带有 name 属性和值的对象。最后,使用 getQuery() 方法获取 name 属性的值。
文件名:app.js
// 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 studentSchema = new mongoose.Schema({
name: { type: String },
age: { type: Number },
rollNumber: { type: Number },
});
const Student = connectionObject.model('Student', studentSchema);
const query = Student.findByIdAndUpdate(
{ _id: '63a4a9a207370cdcd1961b2c' },
{ name: 'Student2' }
);
query.setQuery({ name: 'Student2' });
console.log(query.getQuery('name'));
运行程序的步骤: 要运行该应用程序,请从项目的根目录执行以下命令:
node app.js
输出:
{ name: 'Student2' }
示例2: 下面的示例说明了Mongoose连接 setQuery() 方法的基本功能。在这个示例中,我们定义了一个带有 age 和 _id 属性和值的对象。最后,使用 getQuery() 方法,我们获取包含所有属性的对象。
文件名:app.js
// 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 studentSchema = new mongoose.Schema({
name: { type: String },
age: { type: Number },
rollNumber: { type: Number },
});
const Student = connectionObject.model('Student', studentSchema);
const query = Student.find({ name: 'Student3' });
query.setQuery({ _id: '63a4a98407370cdcd1961b1a', age: 33 });
const result = query.getQuery();
console.log(result);
运行程序的步骤: 要运行该应用程序,请从项目的根目录执行以下命令:
node app.js
输出:
{ _id: '63a4a98407370cdcd1961b1a', age: 33 }
参考链接: https://mongoosejs.com/docs/api/query.html#query_Query-setQuery