MongoDB 按照某个字段分组,并按照分组的记录数降序排列

以下是一个示例查询:

php 复制代码
db.collection.aggregate([
  {
    $group: {
      _id: "$quoteId", // 按照quoteId字段进行分组
      count: { $sum: 1 } // 统计每个分组的记录数
    }
  },
  {
    $sort: {
      count: -1 // 按照记录数降序排序
    }
  }
])

在这个查询中:

  • group** 阶段将文档按照**quoteId** 字段进行分组,并使用**sum 操作符统计每个分组的记录数,保存为count字段。

  • $sort 阶段按照count字段降序排序,这样最多记录数的分组将排在前面。

你需要将db.collection替换为你的集合名称。

为什么会突然间学这个用法呢?

因为看到开发在mysql表里面某个字段长度设置的是2048,有其他开发提出了疑问,会不会有这么长,然后我就查了一下现有数据去确认一下大概字符长度。

相关推荐
老衲提灯找美女3 分钟前
数据库事务
java·大数据·数据库
会飞的大可23 分钟前
Redis 竞品与替代方案选型可行性分析报告
数据库·redis·缓存
周杰伦的稻香29 分钟前
PostgreSQL基础命令
数据库·postgresql
先做个垃圾出来………43 分钟前
JSON序列化问题
数据库·json
我科绝伦(Huanhuan Zhou)1 小时前
InnoDB Undo Log 深度解析:从原理到实现(基于 MySQL 8.0)
数据库·mysql
jackiehome1 小时前
SQL数据库无法操作,日志文件损坏修复
数据库·sql·oracle
荒川之神1 小时前
ORACLE导入导出实验
数据库·oracle
执笔为剑1 小时前
利用逻辑备份修复误操作的库
数据库·kingbase
程序员夏末2 小时前
【MySQL | 第三篇】 MySQL索引详解
数据库·mysql
leoZ2312 小时前
innodb理解
数据库