没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|使用教程|编辑:龚雪|2014-02-26 14:29:34.000|阅读 1139 次
概述:NCReport是一款轻量级、快速、多平台、简单易用的基于Qt toolkit的C++编写的报表解决方案,目前主要包括报表渲染库和报表设计器GUI应用程序。本文主要讲解NCreport报表控件中的子查询系统的设计。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
数据报表中经常需要用到主从数据关系,比如发票、订单等一类的特殊文件,在报表控件NCreport中也不例外。数据报表至少有一个表头和一个通过主键和外键关联的相关细节数据集。子查询系统则是通过父数据源驱动重复的执行SQL子查询,这个可以通过一个ID组实现,而这个组大部分是父主键和子外键。由于这个数据是通过SQL命令进行数据库检索,所以这个工作主要是针对于SQL数据源。
在后面将会创建一个像上面的三层的数据源层次结构,来讲解如何定义主从关系的数据源。
定义一个父数据源
首先在数据源对话框中添加主数据源,通过在设计器中点击“报表”>> “数据源和添加一个新的SQL数据源”,设置Opening role为报表的开始,这就意味着当在报表开始的时候查询将会被执行,键入数据源ID,设置属性关系并在SQL编辑器文本框中编辑SQL查询。
下面的示例是主查询客户:
SELECT customers.CustomerID, customers.CompanyName, customers.CompanyName FROM orders INNER JOIN customers ON orders.CustomerID=customers.ContactName WHERE OrderDate between ’2005-03-01’ and ’2005-03-31’ GROUP BY CustomerID
定义子数据源
在数据源对话框中,我们必须要在父/子结构中添加多于2个的数据源,第一个的时候就需要添加一个新的SQL数据源。设置Opening role为Child datasource,这个就是说当处理下一个主记录时,就会重复的执行查询。键入数据源ID,并在SQL关系面板中设置关系属性,之后键入父数据源ID,这个ID就是之前定义的父数据源。
在sql文本框编辑器中编辑SQL查询,这个是第一个子查询,它将会在一段日期时间内查询和用户相关的订单头。
SELECT OrderID,CustomerID,EmployeeID,OrderDate,ShipName FROM orders WHERE CustomerID=’$D{customers.CustomerID}’ AND OrderDate between ’2005-03-01’ and ’2005-03-31’ ORDER BY OrderID
从这里可以看出,数据关系现在是由一个关系表达式$D{customers.- CustomerID}来管理,我们需要插入父数据源的key值到SQL命令中。
之后出现第二个子数据源,这个是第三层关系,设置Opening role为Childdatasource,键入Parent data source id,并在SQL编辑器文本框中编辑SQL查询,这个查询将把检索命令项关联到一个指定的命令ID:
SELECT OrderID, orderitems.UnitPrice, Quantity, Itemno, products.productname, orderitems.UnitPrice Quantity as Value * FROM orderitems INNER JOIN products ON orderitems.productID = products.productID WHERE OrderID=$D{orders.OrderID} ORDER BY Itemno
设置的Detail部分
在这一步就是要指定合适的数据源到Detail部分,打开Report>Details and grouping…菜单,就会出现Detail部分的属性对话框,选择之前定义好的在结构上最低层的数据源。
报表设计
在定义完数据源并指定它们到Detail之后,我们需要通过数据组按钮添加属性组到Detail,就像通常的每个数据源层关系到一个组层。
添加其他报表部分和报表项目并设置对齐,最终的报表效果如下所示:
>>>NCReport下载
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn
文章转载自:慧都科技FastReport .NET 的主要功能之一是能够将多份报告合并为一份。当您需要合并来自不同来源的数据或以更方便的格式呈现信息时,此功能非常有用。在本文中,我们将讨论如何在 FastReport .NET 中将多份报告合并为一份。
本文将手把手教你如何用VMProtect对这一关键函数进行虚拟化保护,大幅提升代码安全性,让逆向工程攻击者无从下手!
在 PDF 文档中添加页眉和页脚有助于保持一致的版式和专业的外观。本文将介绍如何使用 Spire.PDF for Java,通过 Java 在现有的 PDF 文档中添加页眉和页脚,并提供详细的步骤和代码示例。
对于开发人员来说,由于自动化和定制化,通常首选使用编程方法来去除 PDF 中的水印。Aspose.PDF 提供可靠且可定制的解决方案,可无缝集成到各种应用程序中,确保准确性并保持文档完整性。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@wqylolg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢