FineReport制作可动态展开的组织递归树报表
2015-07-24 09:57
120 查看
先看看效果:
报表软件:FineReport
1.分析-与正常查询的对比
如果不做这种树状结构展开的报表的话,正常的SQL应该是这样写的,以单据表为例,假设单据的机构为分公司,经营部
select 分公司编码,分公司名称,经营部编码,经营部名称,sum(数量) 总数量,sum(金额) 总金额
from order_header,order_itemoi
whereoh.order_id=oi.order_id
andoh.party_id_from in ('$(分公司编码)')
andoh.confirm_date >to_date('${startDatre}','yyyy-mm-dd')
andoh.confirm_date<to_date('${endDatre}','yyyy-mm-dd')+1
group by 分公司编码,分公司名称,经营部编码,经营部名称
2.SQL-over partition的应用
如果要做成在经营部级别汇总金额和数量,同时在分公司级别也要汇总数量和金额的话,那么,需要在1中的基础上做增加,在每一行上增加一列,来表示当前行所在的分公司的汇总的金额和数量,SQL如下
select 分公司编码,分公司名称,经营部编码,经营部名称,
sum(数量) 经营部总数量,sum(sum(数量)) over (partition by 分公司编码) 分公司数量,
sum(金额) 经营部总金额,sum(sum(金额)) over (partition by 分公司编码) 分公司金额
fromorder_header,order_item oi
whereoh.order_id=oi.order_id
andoh.party_id_from in ('$(分公司编码)')
andoh.confirm_date >to_date('${startDatre}','yyyy-mm-dd')
andoh.confirm_date<to_date('${endDatre}','yyyy-mm-dd')+1
group by 分公司编码,分公司名称,经营部编码,经营部名称
3.展示界面的设置和访问注意事项
展示界面的设置,一点点写比较麻烦,我就不讲了。最后,访问的时候需要在url后面加上参数op=sheet
报表软件:FineReport
1.分析-与正常查询的对比
如果不做这种树状结构展开的报表的话,正常的SQL应该是这样写的,以单据表为例,假设单据的机构为分公司,经营部
select 分公司编码,分公司名称,经营部编码,经营部名称,sum(数量) 总数量,sum(金额) 总金额
from order_header,order_itemoi
whereoh.order_id=oi.order_id
andoh.party_id_from in ('$(分公司编码)')
andoh.confirm_date >to_date('${startDatre}','yyyy-mm-dd')
andoh.confirm_date<to_date('${endDatre}','yyyy-mm-dd')+1
group by 分公司编码,分公司名称,经营部编码,经营部名称
2.SQL-over partition的应用
如果要做成在经营部级别汇总金额和数量,同时在分公司级别也要汇总数量和金额的话,那么,需要在1中的基础上做增加,在每一行上增加一列,来表示当前行所在的分公司的汇总的金额和数量,SQL如下
select 分公司编码,分公司名称,经营部编码,经营部名称,
sum(数量) 经营部总数量,sum(sum(数量)) over (partition by 分公司编码) 分公司数量,
sum(金额) 经营部总金额,sum(sum(金额)) over (partition by 分公司编码) 分公司金额
fromorder_header,order_item oi
whereoh.order_id=oi.order_id
andoh.party_id_from in ('$(分公司编码)')
andoh.confirm_date >to_date('${startDatre}','yyyy-mm-dd')
andoh.confirm_date<to_date('${endDatre}','yyyy-mm-dd')+1
group by 分公司编码,分公司名称,经营部编码,经营部名称
3.展示界面的设置和访问注意事项
展示界面的设置,一点点写比较麻烦,我就不讲了。最后,访问的时候需要在url后面加上参数op=sheet
相关文章推荐
- 使用SecureCRT在远程主机和本地之间传输文件
- 图像分析------连通组件标记算法 分类: 视频图像处理 2015-07-24 09:57 32人阅读 评论(0) 收藏
- 【ubuntu操作系统入门】Ubuntu常用命令大全一
- int与char数组及string转换
- Lua 中的另类For循环
- Spring -- spEL&Bean的生命周期&工厂方法配置Bean
- Java中获得数据库连接的几种方法
- 学习JVM
- 图像处理------基于像素的皮肤检测技术
- 图像处理------基于像素的皮肤检测技术
- iOS开发-清理缓存功能的实现
- 程序优化之循环展开
- 图像处理------基于像素的皮肤检测技术
- Android中dp,px,sp概念梳理以及如何做到屏幕适配
- 华为交换机端口-MAC绑定AND解除绑定
- 编程语言 IDE 对比
- 【从中国到美国轻松跨越】—万网美国硅谷机房上线啦,低至78元/月!
- AcGePoint3d ads_point 转换
- 图像处理------基于像素的皮肤检测技术 分类: 视频图像处理 2015-07-24 09:56 28人阅读 评论(0) 收藏
- CSS overflow:hidden 属性含义