Mongoose Aggregate.prototype.sort()函数

Mongoose Aggregate.prototype.sort()函数

Aggregate sort() 方法是Mongoose API的一部分,用于执行聚合任务。它允许我们根据提供的字段对集合中的所有文档进行排序。它还提供了按升序或降序对输入文档进行排序的灵活性。

语法:

aggregate().sort( { fieldName : sortOrder } )
JavaScript

参数: 此方法接受一个参数,如下所述:

  • string/object: 用于指定集合中字段的名称。我们可以以字符串格式或作为对象提供字段名称,并指定排序顺序。

返回值: 此方法以数组形式返回结果集。

设置Node.js Mongoose模块:

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

npm init
JavaScript

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

npm install mongoose
JavaScript

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

Mongoose Aggregate.prototype.sort()函数

数据库结构:

数据库结构将会是这样的,该集合中包含以下文档。

Mongoose Aggregate.prototype.sort()函数

示例1: 在这个示例中,我们使用mongoose建立了一个数据库连接,并定义了一个userSchema模型,包含两个字段”name”和”bornYear”。最后,我们使用sort()方法按照bornYear字段的升序对结果集进行排序。要按照升序排序,我们需要将bornYear字段的值设为”1″,要按照降序排序,值字段的值应为”-1″。

文件名: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().sort({ 'bornYear': 1 }) 
    .then(result => { 
        console.log(result) 
    })
JavaScript

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

node app.js
JavaScript

输出:

[
  {
    _id: new ObjectId("6387aa99c92df30f995e8309"),
    name: 'Aakash',
    bornYear: 2000,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830a"),
    name: 'Ayush',
    bornYear: 2000,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830b"),
    name: 'Rahul',
    bornYear: 2000,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830e"),
    name: 'Takshwi',
    bornYear: 2018,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830c"),
    name: 'Mivan',
    bornYear: 2019,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830d"),
    name: 'Sidiksha',
    bornYear: 2019,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830f"),
    name: 'Kashwi',
    bornYear: 2021,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e8310"),
    name: 'Kinjal',
    bornYear: 2021,
    __v: 0
  }
]
JavaScript

示例2: 在该示例中,我们使用了通过传递对象数组参数来使用pipeline对象。首先,我们按照bornYear字段按降序进行排序,然后按照name字段按升序进行排序。

文件名: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([{ $sort: { bornYear: -1, name: 1 } }]) 
    .exec((error, result) => { 
        if (error) { 
            console.log(error) 
        } else { 
            console.log(result) 
        } 
    })
JavaScript

运行程序的步骤: 在项目的根目录中,执行以下命令来运行应用程序:

node app.js
JavaScript

输出:

[
  {
    _id: new ObjectId("6387aa99c92df30f995e830f"),
    name: 'Kashwi',
    bornYear: 2021,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e8310"),
    name: 'Kinjal',
    bornYear: 2021,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830c"),
    name: 'Mivan',
    bornYear: 2019,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830d"),
    name: 'Sidiksha',
    bornYear: 2019,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830e"),
    name: 'Takshwi',
    bornYear: 2018,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e8309"),
    name: 'Aakash',
    bornYear: 2000,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830a"),
    name: 'Ayush',
    bornYear: 2000,
    __v: 0
  },
  {
    _id: new ObjectId("6387aa99c92df30f995e830b"),
    name: 'Rahul',
    bornYear: 2000,
    __v: 0
  }
]
JavaScript

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

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程

登录

注册