- MongoDB官方文档中文版
- MongoDB中文手册说明
- MongoDB简介
- 安装 MongoDB
- The mongo Shell
- MongoDB CRUD 操作
- 聚合
- 数据模型
- 事务
- 索引
- 安全
- 安全检查列表
- 启用访问控制
- 身份验证
- 基于角色的访问控制
- TLS / SSL(传输加密)
- 静态加密
- 客户端字段级加密
- 审计
- 网络和配置强化
- 实现字段级别修订
- 安全参考
- 附录
- 变更流
- 复制
- 分片
- 分片键
- 哈希分片
- 范围分片
- 区
- 管理分片区
- 按位置细分数据
- 用于更改SLA或SLO的分层硬件
- 按应用或客户细分数据
- 仅插入工作负载的分布式本地写入
- 管理分片区
- 使用块进行数据分区
- 在分片集群中拆分数据块
- 管理
- 存储
- 存储引擎
- 日志记录
- 管理日志记录
- GridFS
- FAQ:MongoDB 存储
- 存储引擎
- 参考
- 运算符
- 查询与映射运算符
- 更新运算符
- 聚合管道阶段
- 聚合管道操作符
- $abs (aggregation)
- $acos (aggregation)
- $acosh (aggregation)
- $add (aggregation)
- $addToSet (aggregation)
- $allElementsTrue (aggregation)
- $and (aggregation)
- $anyElementTrue (aggregation)
- $arrayElemAt (aggregation)
- $arrayToObject (aggregation)
- $asin (aggregation)
- $asinh (aggregation)
- $atan (aggregation)
- $atan2 (aggregation)
- $atanh (aggregation)
- $avg (aggregation)
- $ceil (aggregation)
- $cmp (aggregation)
- $concat (aggregation)
- $concatArrays (aggregation)
- $cond (aggregation)
- $convert (aggregation)
- $cos (aggregation)
- $dateFromParts (aggregation)
- $dateToParts (aggregation)
- $dateFromString (aggregation)
- $literal (aggregation)
- 查询修饰符
- 数据库命令
- 聚合命令
- 地理空间命令
- 查询和写操作命令
- 查询计划缓存命令
- 认证命令
- 用户管理命令
- 角色管理命令
- 复制命令
- 分片命令
- 会话命令
- 管理命令
- 诊断命令
- 免费监控命令
- 系统事件审计命令
- mongo Shell 方法
- 集合方法
- db.collection.aggregate()
- db.collection.bulkWrite()
- db.collection.copyTo()
- db.collection.count()
- db.collection.countDocuments()
- db.collection.estimatedDocumentCount()
- db.collection.createIndex()
- db.collection.createIndexes()
- db.collection.dataSize()
- db.collection.deleteOne()
- db.collection.deleteMany()
- db.collection.distinct()
- db.collection.drop()
- db.collection.dropIndex()
- db.collection.dropIndexes()
- db.collection.ensureIndex()
- db.collection.explain()
- db.collection.find()
- db.collection.findAndModify()
- db.collection.findOne()
- db.collection.findOneAndDelete()
- db.collection.findOneAndReplace()
- db.collection.findOneAndUpdate()
- db.collection.getIndexes()
- db.collection.getShardDistribution()
- db.collection.getShardVersion()
- db.collection.insert()
- db.collection.insertOne()
- db.collection.insertMany()
- db.collection.isCapped()
- db.collection.latencyStats()
- db.collection.mapReduce()
- db.collection.reIndex()
- db.collection.remove()
- db.collection.renameCollection()
- db.collection.replaceOne()
- db.collection.save()
- db.collection.stats()
- db.collection.storageSize()
- db.collection.totalIndexSize()
- db.collection.totalSize()
- db.collection.update()
- db.collection.updateOne()
- db.collection.updateMany()
- db.collection.watch()
- db.collection.validate()
- 词汇表
- 默认的MongoDB端口
- 默认的MongoDB读/写关注
- 服务器会话
- MongoDB驱动
- FAQ
- 联系我们
- 更多资料
- [快学Mongo]
- [Mongo问题讨论区]
- [Mongo 驱动使用手册]
- 本书使用 GitBook 发布
使用用户首选项数据进行聚合
使用用户首选项数据进行聚合
在本页面
数据模型
考虑一个假设的体育俱乐部,其数据库包含一个users
集合,用于跟踪用户的加入日期,运动偏好,并将这些数据存储在类似于以下内容的文档中:
{
_id : “jane“,
joined : ISODate(“2011-03-02“),
likes : [“golf“, “racquetball“]
}
{
_id : “joe“,
joined : ISODate(“2012-07-02“),
likes : [“tennis“, “golf“, “swimming“]
}
规范化和排序文档
以下操作以大写和字母 order 返回用户名。聚合包括users
集合中所有文档的用户名。您可以这样做以规范化用户名以进行处理。
db.users.aggregate([
{ $project : { name:{$toUpper:“$_id“} , _id:0 } },
{ $sort : { name : 1 } }
])
users
集合中的所有文档都通过管道传递,该管道包含以下操作:
$project 操作:
operator 按
name
字段对结果进行排序。
聚合的结果类似于以下内容:
{
"name" : "JANE"
},
{
"name" : "JILL"
},
{
"name" : "JOE"
}
返回按月加入订单的用户名
以下聚合操作返回按其加入的月份排序的用户名。这种聚合可以帮助生成会员续订通知。
db.users.aggregate([
{ $project :
{
month_joined : { $month : “$joined“ },
name : “$_id“,
_id : 0
}
},
{ $sort : { month_joined : 1 } }
])
管道通过以下操作传递users
集合中的所有文档:
$project operator:
创建两个新字段:
month_joined
和name
。从结果中抑制
id
。除非明确禁止,否则aggregate()方法包含_id
。
$month operator 将
joined
字段的值转换为月份的 integer 表示。然后$project operator 将这些值分配给month_joined
字段。$sort operator 按
month_joined
字段对结果进行排序。
该操作返回类似于以下内容的结果:
{
“month_joined“ : 1,
“name“ : “ruth“
},
{
“month_joined“ : 1,
“name“ : “harold“
},
{
“month_joined“ : 1,
“name“ : “kate“
},
{
“month_joined“ : 2,
“name“ : “jill“
}
返回每月的联接总数
以下操作显示了一年中每个月加入的人数。您可以将此汇总数据用于招聘和营销策略。
db.users.aggregate([
{ $project : { month_joined : { $month : “$joined“ } } } ,
{ $group : { _id : {month_joined:“$month_joined“} , number : { $sum : 1 } } },
{ $sort : { “_id.month_joined“ : 1 } }
])
管道通过以下操作传递users
集合中的所有文档:
$project operator 创建一个名为
month_joined
的新字段。$month operator 将
joined
字段的值转换为月份的 integer 表示。然后$project operator 将值分配给month_joined
字段。$group operator 收集具有给定
month_joined
value 的所有文档,并计算该 value 的文档数量。具体来说,对于每个唯一 value,$group创建一个包含两个字段的新“per-month”文档:_id
,包含带有month_joined
字段及其 value 的嵌套文档。number
,这是一个生成的字段。对于包含给定month_joined
value 的每个文档,$sum operator 将此字段递增 1。
此聚合操作的结果类似于以下内容:
{
“_id“ : {
“month_joined“ : 1
},
“number“ : 3
},
{
“_id“ : {
“month_joined“ : 2
},
“number“ : 9
},
{
“_id“ : {
“month_joined“ : 3
},
“number“ : 5
}
Return 五个 Common“喜欢”
以下聚合收集数据集中前五个最“喜欢”的活动。这种分析有助于规划和未来发展。
db.users.aggregate([
{ $unwind : “$likes“ },
{ $group : { _id : “$likes“ , number : { $sum : 1 } } },
{ $sort : { number : -1 } },
{ $limit : 5 }
])
管道从users
集合中的所有文档开始,并通过以下操作传递这些文档:
- $unwind operator 分隔
likes
array 中的每个 value,并为 array 中的每个元素创建源文档的新 version。
[success] 例子
给出来自用户集合的以下文档:
{ _id : "jane", joined : ISODate("2011-03-02"), likes : ["golf", "racquetball"] }
$unwind
运算符将创建下列文件:{ _id : “jane“, joined : ISODate(“2011-03-02“), likes : “golf“ } { _id : “jane“, joined : ISODate(“2011-03-02“), likes : “racquetball“ }
$group operator 收集
likes
字段具有相同 value 的所有文档,并计算每个分组。有了这些信息,$group创建了一个包含两个字段的新文档:_id
,其中包含likes
value。number
,这是一个生成的字段。对于包含给定likes
value 的每个文档,$sum operator 将此字段递增 1。
- $sort operator 按字段在 reverse order 中对这些文档进行排序。
- $limit operator 仅包含前 5 个结果文档。
聚合的结果类似于以下内容:
{
“_id“ : “golf“,
“number“ : 33
},
{
“_id“ : “racquetball“,
“number“ : 31
},
{
“_id“ : “swimming“,
“number“ : 24
},
{
“_id“ : “handball“,
“number“ : 19
},
{
“_id“ : “tennis“,
“number“ : 18
}
译者:李冠飞
校对:李冠飞
Copyright © 上海锦木信息技术有限公司 all right reserved,由 MongoDB汉化小组 提供技术支持文件修订时间: 2020-10-11 20:53:05