通过 ActiveReports 7.0 实现数据钻取报表

在实际生产环境中,我们往往需要展示一种级联关系的数据,比如客户-订单报表系统中,我们可能需要在第一级报表中列出所有的客户基本信息,通过客户可以查询到相关的订单信息,最后通过订单编号能够查出该订单中所有的明细信息。

发布于 2012/12/10 00:00

在实际生产环境中,我们往往需要展示一种级联关系的数据,比如客户-订单报表系统中,我们可能需要在第一级报表中列出所有的客户基本信息,通过客户可以查询到相关的订单信息,最后通过订单编号能够查出该订单中所有的明细信息。

 

下面我们就使用ActiveReports 7.0 来实现这个报表功能,使用的数据是 NorthWind。

1、创建“客户信息”报表

1.1、在 Visual Studio 中添加一个页面报表,模板项目名称为“ActiveReports 7 Page Report”

1.2、打开报表资源管理器,在DataSources节点中右键,并选择添加数据源。为数据源指定以下属性,Name:NWind;OLE DB Provider:Microsoft.Jet.OLEDB.4.0;Server or file name:定位到NWind.mdb文件.

1.3、添加一个名为AllCustomers的数据集,在Query选项卡中指定查询语句:Select 客户ID,公司名称,联系人姓名 from 客户 order by 客户ID

1.4、从工具箱将ActiveReports 7 Page Report选项卡中的Table控件添加到报表中,并设置每列对应的数据字段。选中客户列的明细行单元格,并打开属性设置对话框,在Navigation选项卡中设置以下属性:

2、创建“客户订单”报表

2.1、按照1.2中的方法创建数据源

2.2、添加名为 “Orders”的数据集,Query选项卡中设置查询字符串:Select 客户ID,订单ID,雇员ID,订购日期,到货日期 from 订单 where 订单.客户ID in (?) ;Parameters选项卡中添加一个查询参数,Name:Parameter1,Value:=[@客户ID]

2.3、从工具箱将ActiveReports 7 Page Report选项卡中的Table控件添加到报表中,并设置每列对应的数据字段。选中订单编号列的明细行单元格,并打开属性设置对话框,在Navigation选项卡中设置以下属性:

3、创建“订单明细”报表

3.1、按照1.2中的方法创建数据源

3.2、添加名为 “OrderDetails”的数据集,Query选项卡中设置查询字符串:Select * from [订单明细] Where [订单明细].订单ID IN (?) ;Parameters选项卡中添加一个查询参数,Name:订单ID,Value:=[@订单ID]

 

运行截图:

 

源码下载:VS2010 + ActiveReports 7.0

7271_DrillDown.zip (207.54 kb)

关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的开发者社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

推荐相关案例
推荐相关资源
关注微信
葡萄城社区二维码

关注“葡萄城社区”

加微信获取技术资讯

加微信获取技术资讯

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态