返回顶部
首页 > 资讯 > 数据库 >集算器协助MongoDB计算之交叉汇总
  • 313
分享到

集算器协助MongoDB计算之交叉汇总

2024-04-02 19:04:59 313人浏览 泡泡鱼
摘要

mongoDB实现交叉汇总比较困难,如果将数据取出,用Java等高级语言来汇总的话,也相当复杂。因此,可以考虑用集算器esProc辅助MonGoDB完成交叉汇总。下面我们通过一个例子来看一下具体做法。&nb

mongoDB实现交叉汇总比较困难,如果将数据取出,用Java等高级语言来汇总的话,也相当复杂。因此,可以考虑用集算器esProc辅助MonGoDB完成交叉汇总。下面我们通过一个例子来看一下具体做法。

  Student集合如下:

db.student.insert  ( {school:'school1', sname : 'Sean' , sub1:4, sub2 :5 })

db.student.insert  ( {school:'school1', sname : 'chris' , sub1:4, sub2 :3 })

db.student.insert  ( {school:'school1', sname : 'becky' , sub1:5, sub2 :4 })

db.student.insert  ( {school:'school1', sname : 'sam' , sub1: 5,sub2 :4 })

db.student.insert  ( {school:'school2', sname : 'dustin' , sub1:2, sub2 :2 })

db.student.insert  ( {school:'school2', sname : 'greg' , sub1:3, sub2 :4 })

db.student.insert  ( {school:'school2', sname : 'peter' , sub1:5, sub2 :1 })

db.student.insert  ( {school:'school2', sname : 'brad' , sub1:2, sub2 :2 })

db.student.insert  ( {school:'school2', sname : 'liz' , sub1: 3,sub2 :null })

  希望能够统计出如下的交叉表:每行一个学校,第一列是sub1成绩为5的人数,第二例是sub1成绩为4的人数,以此类推。

集算器协助MongoDB计算之交叉汇总

集算器的脚本如下:

集算器协助MongoDB计算之交叉汇总

  A1: 连接MongoDB数据库,ip和端口号是localhost:27017,数据库是test,用户名和密码都是test。

  A2: 使用find函数从MongoDB中取出集合student,形成游标。esProc在find函数中采用了和mongdb的find语句一样的参数格式。esProc的游标是分批读取和处理数据,可以避免数据量过大,内存出现溢出的情况。这里数据量不大,所以用fetch函数一次取出。

  A3:首先按照学校分组。

  A4:学校分组之后,每组内部按照[1,2,3,4,5]的序列对齐分组,再求每一个对齐分组的长度。

  A5:对A4的长度数按照需求放入相应的位置,生成结果排列。

  结果如下:

集算器协助MongoDB计算之交叉汇总


需要说明的是:集算器esProc并不包含MongoDB的java驱动包。用esProc来访问MongoDB,必须提前将MongoDB的java驱动包(要求2.12.2或以上版,如mongo-java-driver-2.12.2.jar)放到[esProc安装目录]\common\jdbc中。

集算器esProc协助MongoDB计算的脚本很容易集成到java中,只要增加一行,写成resultA5即可向java输出resultset形式的结果,具体的代码参考esProc教程。同样,用java调用esProc访问MongoDB也必须将mongdb的java驱动包放到java程序的classpath中。




您可能感兴趣的文档:

--结束END--

本文标题: 集算器协助MongoDB计算之交叉汇总

本文链接: https://lsjlt.com/news/41015.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 集算器协助MongoDB计算之交叉汇总
    MongoDB实现交叉汇总比较困难,如果将数据取出,用Java等高级语言来汇总的话,也相当复杂。因此,可以考虑用集算器esProc辅助MongoDB完成交叉汇总。下面我们通过一个例子来看一下具体做法。&nb...
    99+
    2024-04-02
  • 集算器协助MongoDB计算之子查询
    MongoDB不支持子查询,碰到这些复杂的运算就只能先将数据读出后再计算,而用Java等语言编写这类计算也不是很简单,这时可以考虑用集算器esProc辅助实现。下面我们通过一个例子来看一下具体做法。Mong...
    99+
    2024-04-02
  • 集算器协助MongoDB计算之数位比较
      Mongodb脚本解决复杂问题的计算能力有限,直接使用时较为吃力。很多情况下需要将数据读出后在主程序中进一步完成运算,而在Java等高级语言中编写这类集合式运算也比较麻烦。这时可以用集算器es...
    99+
    2024-04-02
  • 集算器协助MongoDB计算之本地化排序
    对于本地化语言(例如:中文),MongoDB是按照UNICODE编码排序,而不是根据本地语言的编码排序。用esProc结合MongoDB可以方便的实现本地化语言的排序(例如:中文按照拼音排序)。下面我们以中...
    99+
    2024-04-02
  • 集算器协助MongoDB之表间关联
        MongoDB不支持join,其官网上推荐的unityjdbc可以把数据取出来进行二次计算实现join运算,但收费版才有这个功能。其他免费的jdbc drive只能支持最基本的S...
    99+
    2024-04-02
  • 科学计算NumPy之Ndarray运算函数操作示例汇总
    目录NumPy比较运算符NumPy逻辑运算符逻辑与逻辑或逻辑异或逻辑非NumPy逻辑运算函数logical_and()函数np.logical_or()函数logical_not()...
    99+
    2023-05-18
    NumPy Ndarray运算函数 NumPy Ndarray操作汇总
  • 集算器协助java处理结构化文本的集合运算是怎样的
    今天就跟大家聊聊有关集算器协助java处理结构化文本的集合运算是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。JAVA不直接支持集合运算,因此要用嵌套循环才能实现文本文件之间的...
    99+
    2023-06-17
  • 计算机网络之五:基本器件(网卡,集线器,交换机,路由器)
    一:RJ45接口通常用于数据传输,最常见的应用为网卡接口。是一种网卡上用的标准接口,用来插网线的。RJ45是布线系统中信息插座(即通信引出端)连接器的一种,连接器由插头(接头、水晶头)和插座(模块)组成,插头有8个凹槽和8个触点。RJ是Re...
    99+
    2023-06-03
  • 集算器怎么协助Java处理结构化文本实现条件过滤
    这篇文章主要讲解了“集算器怎么协助Java处理结构化文本实现条件过滤”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“集算器怎么协助Java处理结构化文本实现条件过滤”吧!直接用Java实现文本...
    99+
    2023-06-17
  • 集算器怎么协助java处理结构化文本实现对齐连接
    这篇文章主要讲解了“集算器怎么协助java处理结构化文本实现对齐连接”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“集算器怎么协助java处理结构化文本实现对齐连接”吧!文本文件emp.txt...
    99+
    2023-06-17
  • 阿里云服务器配置教学软件——助力您的云计算之旅
    随着云计算技术的不断发展,越来越多的企业和个人开始使用阿里云服务器。然而,对于初次接触阿里云服务器的人来说,如何配置和使用阿里云服务器可能是一项挑战。为了帮助大家快速掌握阿里云服务器的配置,我们编写了这篇阿里云服务器配置教学软件的详细介绍文...
    99+
    2023-10-30
    您的 阿里 之旅
  • Windows服务器无法启用"允许远程协助连接这台计算机"的解决方法
    目录Windows 2008解决方案Windows 2012 2016 2019解决方案问题描述 Windows系统服务器在开启远程协助时,会出现远程协助灰色并无法勾选开启的情况。 ...
    99+
    2023-05-18
    允许远程协助
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作