当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Mongoose Aggregate.prototype.sortByCount()用法及代码示例


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

用法:

aggregate().sortByCount(expression)

Parameters: 该方法接受如上所述和如下所述的单个参数:

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

返回值:它返回一个对象数组,每个对象都会有_id数数键在哪里_id将是给定字段的独特值并且数数将是它出现的次数。

设置 Node.js Mongoose 模块:

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

npm init

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

npm install mongoose

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

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

示例 1:在此示例中,我们使用 mongoose 建立了数据库连接,并通过phoneSchema定义了模型,具有三列或字段“name”、“companyName”和“manufacturingYear”。最后,我们呼吁sortByCount()方法并将字段名称作为字符串值传递,我们需要 sortByCount 函数。

文件名:app.js

Javascript


// 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”。最后,我们呼吁aggregate()用户模型上的方法并传递管道对象$sorByCount作为钥匙和$bornYear这是 MongoDB 集合中作为值的字段。

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

文件名:app.js

Javascript


// 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



相关用法


注:本文由纯净天空筛选整理自sakshio0hoj大神的英文原创作品 Mongoose Aggregate.prototype.sortByCount() API。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。