`
datamachine
  • 浏览: 163407 次
社区版块
存档分类
最新评论

MongoDB系列之分组topN

    博客分类:
  • DB
阅读更多

   来源:https://groups.google.com/forum/#!topic/mongodb-user/Rjv6lyUCe1s

Collction last3有两个字段:variabletimestamp,需要先按variable分组,选出每组文档中timestamp最晚的3个,再从这些文档中找到timestamp最早的1个。

last3的部分数据如下:



 

   集算器代码:



 

A1:连接MongoDB,连接字格式为mongo://ip:port/db?arg=value&…

A2:使用find函数从MongoDB中取数并排序,形成游标。collectoinlast3,过滤条件是空,取出_id之外的所有字段,并按variable排序。集算器的find函数和mongdbfind+sort+limit函数类似,过滤条件的写法遵循mongodb规范。

        A3:循环从游标读数,每次取variable字段相同的一组文档。A3的作用范围是缩进的B3B4,其间可以用A3来引用循环变量。A3是内存数据,某次取数的结果如下:



 

B3:选出本组文档中timestamp最晚(大)的3个。

        B4:B3不断地追加到B2中。B2如下:



 

A5:选出B2timstamp最早(小)的那个文档,即:



 

A6:关闭MongoDB连接。

  • 大小: 123.2 KB
  • 大小: 28.5 KB
  • 大小: 15 KB
  • 大小: 31.8 KB
  • 大小: 5.9 KB
1
1
分享到:
评论

相关推荐

    MongoDB聚合分组取第一条记录的案例与实现方法

    总的来说,这个案例展示了如何在MongoDB中处理复杂的数据操作,包括数据分组、排序和选择特定记录。理解并熟练运用MongoDB的聚合框架是优化数据处理的关键,特别是在实时分析和大数据场景下。在面对类似的需求时,应...

    MongoDB系列之二:简单操作

    在这个“MongoDB系列之二:简单操作”中,我们将深入探讨MongoDB的基本操作,包括安装、启动、数据插入、查询、更新以及删除等核心功能。 首先,MongoDB的安装通常很简单,支持多种操作系统,如Windows、Linux和...

    MongoDB系列之一:windows安装

    MongoDB是一款分布式文档型数据库,常用于处理大量数据。它以JSON格式存储数据,具有高性能、高可用性和可扩展性的特点。本篇文章将详细介绍在Windows操作系统上安装MongoDB的过程。 一、准备工作 在开始安装...

    mongodb分组

    在MongoDB中,分组(Group)操作是用于聚合数据并按特定字段进行统计分析的重要功能。本篇将深入探讨MongoDB的分组统计以及如何在Java开发环境中实现相关查询。 一、MongoDB的分组操作 MongoDB的分组功能是通过`$...

    MongoDB之conf配置文件详解

    MongoDB之conf配置文件详解 MongoDB的配置文件是服务器的核心组件之一,它控制着MongoDB服务器的各种设置和行为。在本文中,我们将详细介绍MongoDB的配置文件的各个部分,并解释每个设置的作用和意义。 一、数据库...

    浅析mongodb中group分组

    先选定分组所依据的键,此后MongoDB就会将集合依据选定键值的不同分成若干组。然后可以通过聚合每一组内的文档,产生一个结果文档。 和数据库一样group常常用于统计。MongoDB的group还有很多限制,如:返回结果集不...

    mongoTemplate实现统计和分组

    "MongoDB 使用 MongoTemplate 实现统计和分组" MongoDB 是一个非常流行的 NoSQL 数据库,它可以存储大量的数据,但是有时候我们需要对这些数据进行分析和利用。在本文中,我们将介绍如何使用 MongoTemplate 实现...

    linux安装mongodb教程

    /usr/local/mongodb/mongodb-linux-2.0.7/bin/mongod --dbpath=/usr/local/mongodb/data/db --logpath=/usr/local/mongodb/mongodb-linux-2.0.7/logs/mongodb.log --logappend --port=27017 --fork 知识点 6:配置...

    MongoDB学习笔记之分组(group)使用示例

    在MongoDB中,分组操作是数据分析和统计的关键部分,它允许我们根据指定的字段对数据进行聚合,以便进行更深入的分析。在本文中,我们将深入探讨MongoDB的分组功能,特别是`group`命令的使用,以及如何通过示例来...

    MongoDB入门指南.pdf

    MongoDB还支持聚合操作,可以对数据进行分组、排序、过滤等操作。 MongoDB中的Journaling是指将数据库的操作日志记录到磁盘上,以便在系统崩溃时可以快速地恢复数据。MongoDB的原子性和事务机制可以确保数据的一致...

    JAVA操作MongoDB之spring整合

    总结来说,"JAVA操作MongoDB之spring整合"涉及到的主要知识点包括:Spring Boot项目结构,MongoDB的配置和连接,Spring Data MongoDB的MongoRepository接口,以及如何在Controller层处理HTTP请求。通过这样的整合,...

    开源数据库之MongoDB专场

    开源数据库之MongoDB专场

    mongodb-测试数据

    MongoDB是一种流行的开源、分布式文档数据库,常被用于构建高性能、可扩展的应用程序。这个“mongodb-测试数据”压缩包显然包含了一些用于测试MongoDB功能的样例数据集,特别是针对增、删、改、查(CRUD)操作的学习...

    spring-data使用mongodbTemplate对MongoDB进行读写操作

    除了基本操作,`MongoDBTemplate`还支持聚合框架,可以处理复杂的聚合操作,如分组、管道等。另外,它还提供了索引管理和事件监听等功能,帮助优化数据库性能和实现业务逻辑。 在项目结构中,`jdbc4mongodb`可能是...

    mongodb Windows7 64位

    - 性能指标:使用`top`命令或者第三方工具(如MongoDB Compass)监控数据库的性能,如内存使用、磁盘I/O等。 7. **集群和复制集** - 集群:MongoDB支持分片集群,可以水平扩展存储和处理能力。这需要多个MongoDB...

Global site tag (gtag.js) - Google Analytics