當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


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。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。