Skip to content
Related Articles
Open in App
Not now

Related Articles

Mongoose Query.prototype.setOptions() API

Improve Article
Save Article
  • Last Updated : 11 Jan, 2023
Improve Article
Save Article

The Mongoose Query API.prototype.setOptions() method of the Mongoose API is used on the Query objects. It allows us to set query options to be executed for the method. Certain operations are available for specific methods only. Let us understand setOptions() method using an example.

Syntax:

query.setOptions( object );

Parameters: This method accepts a single parameter as described below:

  • object: It is used to specify the query condition object.

Return Value: This method returns the Query object, on which we can call callback function.

Setting up Node.js Mongoose Module:

Step 1: Create a Node.js application using the following command:

npm init

Step 2: After creating the NodeJS application, Install the required module using the following command:

npm install mongoose

Project Structure: The project structure will look like this: 

 

Database Structure: The database structure will look like this, the following database present in the MongoDB.

 

Example 1: The below example illustrates the basic functionality of the Mongoose Connection setOptions() method. In this example, we are sorting the result set based on rollNumber field in ascending order. 

Filename: app.js

Javascript




// Require mongoose module
const mongoose = require("mongoose");
  
// Set Up the Database connection
  
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();
query.setOptions({ sort: { rollNumber: 1 } })
query.then(result => {
    console.log(result);
})


Step to run the program: To run the application execute the below command from the root directory of the project:

node app.js

Output:

[
  {
    _id: new ObjectId("63a40a1065e8951038a391b1"),
    name: 'Student1',
    age: 30,
    rollNumber: 9,
    __v: 0
  },
  {
    _id: new ObjectId("63a4a9a207370cdcd1961b2c"),
    name: 'Student2',
    age: 18,
    rollNumber: 176,
    __v: 0
  },
  {
    _id: new ObjectId("63a4a98407370cdcd1961b1a"),
    name: 'Student3',
    age: 33,
    rollNumber: 178,
    __v: 0
  }
]

Example 2: The below example illustrates the basic functionality of the Mongoose Connection setOptions() method. In this example, we are skipping the first 2 records from the result set.

Filename: app.js

Javascript




// Require mongoose module
const mongoose = require("mongoose");
  
// Set Up the Database connection
  
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();
query.setOptions({ skip: 2 })
query.exec((error, result) => {
    if (error) {
        console.log(error);
    } else {
        console.log(result)
    }
})


Step to run the program: To run the application execute the below command from the root directory of the project:

node app.js

Output:

[
  {
    _id: new ObjectId("63a4a9a207370cdcd1961b2c"),
    name: 'Student2',
    age: 18,
    rollNumber: 176,
    __v: 0
  }
]

Reference: https://mongoosejs.com/docs/api/query.html#query_Query-setOptions


My Personal Notes arrow_drop_up
Related Articles

Start Your Coding Journey Now!