Mongoose Query.prototype.and()函数

Mongoose Query.prototype.and()函数

Mongoose Query API and() 方法用于向当前mongoose查询实例添加附加过滤器。

语法 :

Query.prototype.and(array)

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

  • array(数组): 它是一个要连接到当前mongoose查询实例的条件数组。

返回类型: 它以一个Query对象作为响应返回。

创建Node应用程序和安装Mongoose:

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

mkdir folder_name
cd folder_name
npm init -y
touch main.js

步骤2: 完成Node.js应用程序后,使用以下命令安装所需模块:

npm install mongoose

示例1: 在这个示例中,我们将使用该方法将年龄为“20”的额外过滤器添加到查询实例中

文件名: 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)
    const res = await Person.find().and([{ age: 20 }])
    console.log({ res });
})();

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

node main.js

输出:

Mongoose Query.prototype.and()函数

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

Mongoose Query.prototype.and()函数

示例2: 在这个示例中,我们将使用这个方法将年龄“20”和姓名“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.find().and([{ age: 20 },
    { name: "Luffy" }])
    console.log({ res });
})();

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

node main.js

输出:

Mongoose Query.prototype.and()函数

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

Mongoose Query.prototype.and()函数

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

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程