Mongoose Query.prototype.selectedExclusively() 函数

Mongoose Query.prototype.selectedExclusively() 函数

Mongoose 是MongoDB的对象数据建模(ODM)库。它定义了一个强类型的模式,具有默认值和模式验证,后者稍后映射到MongoDB文档中。

Mongoose Query API selectedExclusively方法 用于确定是否使用Mongoose select()查询进行独占选择。让我们通过一些示例来更好地理解这个问题。

语法:

Query.prototype.selectedExclusively()
JavaScript

参数: 不需要任何参数

返回类型: 返回一个布尔值 | 对象响应

创建节点应用程序并安装Mongoose:

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

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

步骤2: 创建ReactJS应用后,使用以下命令安装所需模块:

npm install mongoose
JavaScript

项目结构: 它将看起来像下面这样。

Mongoose Query.prototype.selectedExclusively() 函数

使用MongoDB Compass的GUI表示数据库 : 当前集合中没有数据。

Mongoose Query.prototype.selectedExclusively() 函数

示例1: 在此示例中,我们将使用Query API的selectedExclusively()方法来确定是否进行了“age”取消选择。

文件名: main.js

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: 22 
    }, 
    { 
        name: 'Nami', 
        age: 30 
    }, 
    { 
        name: 'Zoro', 
        age: 15 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    const query = Person.find() 
  
    console.log(query.selectedExclusively()); 
    query.select('-age') 
    console.log(query.selectedExclusively()); 
})() 
JavaScript

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

node main.js
JavaScript

输出: 我们看到结果中的值保持不变。

Mongoose Query.prototype.selectedExclusively() 函数

MongoDB Compass 中数据库的图形用户界面表示:

Mongoose Query.prototype.selectedExclusively() 函数

示例2: 在这个示例中,我们将使用Query API的selectedExclusively()方法来确定是否进行了“age”的取消选择。在这里,我们将首先取消选择和选择“age”,这将使得两个控制台日志都打印出“null”作为响应。

文件名: main.js

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: 22 
    }, 
    { 
        name: 'Nami', 
        age: 30 
    }, 
    { 
        name: 'Zoro', 
        age: 15 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    const query = Person.find() 
  
    console.log(query.selectedExclusively()); 
    query.select('-age') 
    query.select('age') 
    console.log(query.selectedExclusively()); 
})() 
JavaScript

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

node main.js
JavaScript

输出: 我们可以看到结果中数值保持不变。

Mongoose Query.prototype.selectedExclusively() 函数

用 MongoDB Compass 表示数据库的图形用户界面(GUI):

Mongoose Query.prototype.selectedExclusively() 函数

参考资料: https://mongoosejs.com/docs/api/query.html#query_Query-selectedExclusively

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程

登录

注册