【帆软】固定样式汇总报表

文章目录


前言

【帆软FineReport】​ 聚焦企业级数据可视化与报表开发。本专栏深入解析 FineReport​ 与 FineBI​ 核心技巧,涵盖复杂报表设计、参数联动、填报功能及大屏可视化(决策平台)。

拒绝空谈理论,专注解决数据孤岛、报表自动化及性能优化等企业痛点。我将分享多年沉淀的帆软开发套路与 SQL 优化经验,助你快速从"取数工具人"进阶为"数据架构师"。关注我,用报表驱动业务增长!

一、需求描述

分类汇总报表,计算复卷率。

二、技术要点

${cboMachineId}:输入框传参

COALESCE​:SQL 中用于处理 NULL 值​ 的核心函数,它返回参数列表中第一个非空(NOT NULL)的值。如果所有参数都为 NULL,则返回 NULL。

三、解决方案

数据集脚本:

sql 复制代码
WITH
-- 淋膜产出
lm_output_links as (
	select tax0009.C_GROUP_LINE,top3230.*
	from Top_3230 top3230
	inner join tax_0009 tax0009 on tax0009.C_MACHINE_CD=top3230.C_MACHINE_ID
	inner join top_3240 top3240 on top3240.C_PAPERROLL_NO=top3230.C_PAPERROLL_NO
	where 
		top3230.C_PROC_CD='10028' and top3240.C_PAPERROLL_NO like 'L%' 
		and	(tax0009.C_GROUP_LINE='${cboMachineId}' or '${cboMachineId}'='')
		and (top3230.C_CLASS_GROUP='${cboClassGroup}' or '${cboClassGroup}'='')
		and top3230.D_OUTPUT_TIME > '${dateEditor0}' AND top3230.D_OUTPUT_TIME <= '${dateEditor1}' 
),
-- 淋膜产出汇总
lm_table as (
	select op.D_OUTPUT_TIME,op.C_GROUP_LINE,op.C_CLASS_GROUP,count(1) lmjs,sum(N_WGT) lmwgt
	from lm_output_links op
	group by op.D_OUTPUT_TIME,op.C_GROUP_LINE,op.C_CLASS_GROUP	
),
-- 复卷产出明细
fj_table AS (
	select mm.D_OUTPUT_TIME,mm.C_GROUP_LINE,mm.C_class_group,count(1) as fjjs,sum(N_WGT) as fjwgt 
	from (
		select distinct C.C_BAR_CODE,c.D_OUTPUT_TIME,tax0009.C_GROUP_LINE,a.C_class_group,c.N_WGT
		from top_3240 a  
		inner join top_3130 b on a.C_BAR_CODE =b.C_OLD_BAR_CODE 
		inner join top_3240 c on b.C_OUTPUT_NO =c.C_OUTPUT_NO
		inner join top_3230 d on d.C_BAR_CODE=c.C_BAR_CODE
		inner join tax_0009 tax0009 on tax0009.C_MACHINE_CD=a.C_MACHINE_ID 
		where c.C_PROC_CD ='10004' AND d.C_WORK_TYPE='复卷'
		and	(tax0009.C_GROUP_LINE='${cboMachineId}' or '${cboMachineId}'='')
		and (a.C_CLASS_GROUP='${cboClassGroup}' or '${cboClassGroup}'='')
		and c.D_OUTPUT_TIME > '${dateEditor0}' AND c.D_OUTPUT_TIME <= '${dateEditor1}' 
	) mm group by mm.D_OUTPUT_TIME,mm.C_GROUP_LINE,mm.C_class_group
),
-- 最终结果,合并淋膜和复卷数据
result_table as (	
	SELECT 
	    COALESCE(lm.D_OUTPUT_TIME, fj.D_OUTPUT_TIME) AS D_OUTPUT_TIME,
	    COALESCE(lm.C_GROUP_LINE, fj.C_GROUP_LINE) AS C_GROUP_LINE,
	    COALESCE(lm.C_CLASS_GROUP, fj.C_CLASS_GROUP) AS C_CLASS_GROUP,
	    COALESCE(lm.lmjs, 0) AS lmjs,
	    COALESCE(lm.lmwgt, 0) AS lmwgt,
	    COALESCE(fj.fjjs, 0) AS fjjs,
	    COALESCE(fj.fjwgt, 0) AS fjwgt
	FROM lm_table lm
	LEFT JOIN fj_table fj ON 
		lm.D_OUTPUT_TIME = fj.D_OUTPUT_TIME
	    AND lm.C_GROUP_LINE = fj.C_GROUP_LINE
	    AND lm.C_CLASS_GROUP = fj.C_CLASS_GROUP	   
),
result_table1 as (	
	select t.d_output_time,t.c_group_line,t.c_class_group,sum(t.lmjs) lmjs,sum(t.fjjs) fjjs,sum(t.lmwgt) lmwgt,sum(t.fjwgt) fjwgt
	from result_table t 
	group by t.d_output_time,t.c_group_line,t.c_class_group
)
select * 
,(select sum(t2.fjjs)/sum(t2.lmjs) from result_table1 t2 where t2.d_output_time=t1.d_output_time and t2.c_group_line=t1.c_group_line) as lmlv 
from result_table1 t1
order by t1.d_output_time,t1.c_group_line,t1.c_class_group

样式布局

四、效果展示

相关推荐
Leo.yuan3 小时前
企业数字化转型选型指南:FineBI如何助力数据驱动决策?
数据仓库·人工智能·信息可视化
CodingPioneer3 小时前
智屏问数 · AI数字人驱动的车间数字大屏
人工智能·信息可视化·数字人·魔珐星云·星云具身
AI玫瑰助手3 小时前
Python流程控制:if-else与if-elif-else嵌套使用
开发语言·python·信息可视化
段一凡-华北理工大学3 小时前
高炉炼铁领域炉温监测、预警、调控智能体设计与应用】~系列文章15:可视化界面设计:让数据说话
网络·人工智能·信息可视化·知识图谱·高炉炼铁·工业智能体
财经资讯数据_灵砚智能3 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年5月8日
大数据·人工智能·python·信息可视化·自然语言处理
Elastic 中国社区官方博客14 小时前
在 Elasticsearch 中使用原生 PromQL 支持查询 Prometheus 指标
大数据·elasticsearch·搜索引擎·信息可视化·全文检索·prometheus
Elastic 中国社区官方博客17 小时前
Elastic 9.4:Workflows 正式发布、Agent Builder 更新,以及 Prometheus / PromQL 支持
运维·数据库·人工智能·elasticsearch·搜索引擎·信息可视化·prometheus
chatexcel1 天前
ChatExcel AIPPT实测:基于Excel数据生成PPT,覆盖图表可视化与办公汇报
信息可视化·powerpoint·excel
麟听科技1 天前
HarmonyOS 6.0+ PC端工业物联网设备监控APP开发实战:Modbus协议适配与实时数据可视化落
物联网·信息可视化·harmonyos