Mongoose Aggregate.prototype.sortByCount()函数

Mongoose Aggregate.prototype.sortByCount()函数

Aggregate接口的 sortByCount() 方法用于执行聚合任务。它允许我们按照字段的特定值对集合中的对象进行排序和计数。

语法:

aggregate().sortByCount(expression)

参数: 该方法接受一个参数,如上所述,描述如下:

  • expression: 用于指定要排序和计数的列或字段的名称。

返回值: 它返回一个对象数组,每个对象都有 _id 和 count 键,其中 _id 是给定字段的不同值, count 是其出现次数。

设置Node.js的Mongoose模块:

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

npm init

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

npm install mongoose

项目结构: 项目的结构将如下所示:

Mongoose Aggregate.prototype.sortByCount()函数

数据库结构: 数据库结构将如下所示,以下文档存在于集合中。

Mongoose Aggregate.prototype.sortByCount()函数

示例1: 在这个示例中,我们使用mongoose建立了一个数据库连接,并定义了phoneSchema模型,其中有三个列或字段“name”、“companyName”和“manufacturingYear”。最后,我们调用 sortByCount() 方法,并传递字段名作为我们想要进行sortByCount功能的字符串值。

文件名:app.js

// Require mongoose module 
const mongoose = require("mongoose"); 
  
// Set Up the Database connection 
mongoose.connect("mongodb://localhost:27017/geeksforgeeks", { 
    useNewUrlParser: true, 
    useUnifiedTopology: true, 
}); 
  
const phoneSchema = new mongoose.Schema({ 
    name: String, 
    companyName: String, 
    manufacturingYear: Number, 
}); 
  
const Phone = mongoose.model('Phone', phoneSchema); 
  
Phone.aggregate() 
    .sortByCount('manufacturingYear') 
    .then(result => { 
        console.log(result); 
    }).catch(err => { 
        console.log(err); 
    })

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

node app.js

输出:

[
 { _id: 2021, count: 4 },
 { _id: 2020, count: 3 },
 { _id: 2022, count: 3 } 
]

示例2: 在这个示例中,我们使用mongoose建立了一个数据库连接,并定义了一个名为userSchema的模型,该模型有两个列或字段“name”和“bornYear”。最后,我们在User模型上调用aggregate()方法,并传入pipeline对象,其中sorByCount是键,bornYear是MongoDB集合中的字段。

数据库结构: 数据库结构将如下所示,集合中存在以下文档。

Mongoose Aggregate.prototype.sortByCount()函数

文件名: app.js

// Require mongoose module 
const mongoose = require("mongoose"); 
  
// Set Up the Database connection 
mongoose.connect("mongodb://localhost:27017/geeksforgeeks", { 
    useNewUrlParser: true, 
    useUnifiedTopology: true, 
}); 
  
const userSchema = new mongoose.Schema({ 
    name: String, 
    bornYear: Number 
}); 
  
const User = mongoose.model('User', userSchema); 
  
User.aggregate([{ sortByCount: "bornYear" }]) 
    .exec((error, result) => { 
        if (error) { 
            console.log(error) 
        } else { 
            console.log(result); 
        } 
    })

运行程序的步骤: 要运行该应用程序,请从项目的根目录执行以下命令:

node app.js

输出:

[
  { _id: 2000, count: 3 },
  { _id: 2019, count: 2 },
  { _id: 2021, count: 2 },
  { _id: 2018, count: 1 } 
]

参考: https://mongoosejs.com/docs/api/aggregate.html#aggregate_Aggregate-sortByCount

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程