协助报表开发之 MongoDB join 交叉汇总 位数比较

2024-03-25 11:08

本文主要是介绍协助报表开发之 MongoDB join 交叉汇总 位数比较,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

其他mongodb计算的文章

http://c.raqsoft.com.cn/article/1568626730687?r=CGQ

协助 mongodb 计算之数位比较:http://c.raqsoft.com.cn/article/1568597259340?r=CGQ

协助 MongoDB 计算之交叉汇总

http://c.raqsoft.com.cn/article/1568594893453?r=CGQ

 

 

 

 

 

处理多样性数据源是报表开发中的常见问题,而常见的 JasperReport 等报表工具本身却难以应付,比如展现两个 MongoDB 集合连接的结果。虽然 JasperReport 有 virtual data source 或 table join,但这些功能只在商业版或高端版本出现,在免费版中实现的难度很大。而且这些功能只支持两个数据源的连接,要实现多连接则麻烦得多。另外,这些功能只能基于图形化界面操作,对连接后的数据无法进行类似 SQL 的结构化计算。

       集算器 SPL 语言具有面向结构化处理的强计算引擎,支持多样性数据源,集成简单,可以协助不同报表工具方便地实现此类需求,下面用例子说明。

       Sales和 emp 是 MongoDB 中的两个集合,sales 中的字段 SellerId 逻辑上相当于外键,指向 emp 的 EId 字段,现在需要按时间段查询出 sales 中的订单,并和 emp 进行左连接,最后在报表中展现。部分源数据如下:

   集合sales

OrderIDClientSellerIdAmountOrderDate
26TAS12142.42009-08-05
27HP13538.62010-08-06
28DY11307.22010-08-07
29WVF194202010-08-08
30UFS181200.82009-08-09
31SWFR151488.82010-08-12
32JFS34682009-08-13

集合emp

EIdStateDeptNameGenderSalaryBirthday
2New YorkFinanceAshleyF110011980-07-19
3New MexicoSalesRachelF90001970-12-17
4TexasHREmilyF70001985-03-07
5TexasR&DAshleyF160001975-05-13
6CaliforniaSalesMatthewM110001984-07-07
7IllinoisSalesAlexisF90001972-08-16

使用集算器SPL的代码如下:

 A
1=mongo_open("mongodb://localhost:27017/test?user=root&password=sa")
2=mongo_shell(A1,"sales.find({$and:[{OrderDate:{$gte:'"+string(begin)+"'}},{  OrderDate:{ $lte:'"+string(end)+"'}} ] },{_id:0} )").fetch()
3=mongo_shell(A1,"emp.find(,,"{_id:0}").fetch()
4>mongo_close(A1)
5=join@1(A2:sales,SellerId;A3:emp,EId)
6=A5.new(sales.OrderID:OrderID,sales.Client:Client,sales.Amount:Amount,sales.OrderDate:OrderDate,emp.Name:Name,emp.Dept:Dept,emp.Gender:Gender)
7result   A6

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

A2: 使用 find 函数从集合 sales 中查询出某时间段的记录,取出 _id 之外的所有字段。其中查询条件中的 begin 和 end 是来自报表的外部参数,分别表示 OrderDate 的起始时间和终止时间。

函数 find 返回的是游标,并不会把数据直接读入内存,因此能够很好地支持大数据量。类似的,还可以用 skip、sort、conj 等函数继续操作游标,直到遇到函数 fetch、groups,或语句 for 时才会真正取数。本例直接用函数 fetch() 将数据读入内存,假如时间段是 2009-01-01 到 2009-12-31,则 A2 的计算结果如下:

a_100png

A3: 使用 find 函数从集合 carInfo 中取数,形成游标。过滤条件是空,取出 _id 之外的所有字段,结果如下:

a_101png

A4: 关闭 MongoDB。

A5: 将 A2 和 A3 进行左连接,连接字段是 A2 的 SellerId 和 A3 的 Eld,直观起见,连接后的两部分数据分别命名为 sales 和 emp。函数 join 执行连接计算,选项 @1 表示左连接,计算结果如下图左侧:

a_102png

可以看到,由于是左连接,因此 sales 中部分 SellerId 无法在 emp 中找到对应的记录。如果想进行全连接,可以使用选项 @f,无选项则表示内连接。

A6: 执行连接操作,从连接的结果中取出需要的字段,并用函数 new 组成二维表。比如sales.OrderID:OrderID表示从 A5 取出 sales.OrderID 字段,重命名为 OrderID(报表工具无法识别 sales.OrderID 这样的字段名)。计算结果如下:

a_103png

到此为止,报表需要的数据就全部计算出来了。
A7: 将 A6 中的二维表返回报表工具。
集算器对外提供 JDBC 接口,报表工具会将集算器识别为普通数据库,集成方案请参考相关文档。

接下来以 JasperReport 为例设计报表,表样如下:

a_104png

 需要定义两个报表参数 Pbegin、Pend,分别对应集算器中的两个参数。预览后可以看到报表结果:

a_105png

       报表调用集算器的方法和调用存储过程一样,此例中可以将本脚本保存为 mongodbJoin.dfx,在 JasperReport 的 SQL 设计器中可以用mongodbJoin $P{pbegin},$P{pend}来调用。

       简言之,SPL 从 MongoDB 获取多个集合数据后,将它们通过 join 函数进行连接计算,再通过函数 new 按需求将数据生成序表,供其它的报表工具展示。通过 SPL 对多个集合进行 join 关联,大大简化了对 MongoDB 数据的操作,有利于与其它报表工具的方便集成。

这篇关于协助报表开发之 MongoDB join 交叉汇总 位数比较的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/844792

相关文章

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Mybatis Plus Join使用方法示例详解

《MybatisPlusJoin使用方法示例详解》:本文主要介绍MybatisPlusJoin使用方法示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录1、pom文件2、yaml配置文件3、分页插件4、示例代码:5、测试代码6、和PageHelper结合6

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件