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,有其他开发提出了疑问,会不会有这么长,然后我就查了一下现有数据去确认一下大概字符长度。

相关推荐
IvorySQL13 小时前
PG 技术日报|2026-07-03
数据库·postgresql·开源
长孙豪翔13 小时前
引发事件的问题
java·linux·数据库
吴声子夜歌14 小时前
SQL进阶——HAVING子句
数据库·sql
无小道14 小时前
Redis——哨兵
数据库·redis·缓存·哨兵
闪电悠米14 小时前
黑马点评-Redis Set-实现关注、取关和共同关注
数据库·redis·缓存
爱奥尼欧14 小时前
轻量级可扩展日志框架-异步日志与系统集成
开发语言·数据库·c++·学习
爱奥尼欧15 小时前
轻量级可扩展日志框架-日志落地与日志器模块实现
jvm·数据库·c++
ycydynq15 小时前
Django利用中间间 判断页面是否登录,未登录则返回登录页
数据库·django·sqlite
承渊政道15 小时前
【MySQL数据库学习】(MySQL访问、连接池原理与简易网站数据流动)
数据库·学习·mysql·mysql访问·连接池原理
吴声子夜歌15 小时前
SQL进阶——EXISTS谓词
java·数据库·sql