有时候,将ActiveReports设计器集成到业务系统中,为用户提供一些自定义的数据表,用户不需要了解如何底层的逻辑关系和后台代码,只需要选择几张关联的数据表,我们会根据用户的选择生成可供用户直接使用的数据集。本文第一部分主要讲解了,如何构造三种报表模板,第二部分主要讲解了对于DataRelation类在动态绑定数据集之间的用法。

首先需要构造LayoutBuilder类,该类主要构造三种类型的报表以及为它们添加数据集字段。

1. 创建RDL 报表

使用PageReport对象,并添加属性

 public static void BuildRdlReportLayout(Design.Designer designer)
{
PageReport report = new PageReport(); report.Report.Body.Height = "5cm";
report.Report.Width = "20cm"; report.Load(new StringReader(report.ToRdlString())); //report = LayoutBuilder.AddDataSetDataSource(report);//Adding DataSources to the PageReport object
report = LayoutBuilder.addDataSet(report);
MemoryStream reportStream = LayoutBuilder.LoadReportToStream(report);//Loading the PageReport object to a stream
reportStream.Position = 0; designer.LoadReport(XmlReader.Create(reportStream), DesignerReportType.Page);
}

2. 创建页面报表

页面报表使用页面报表的构造字符串的方式来创建,否则会默认生成RDL报表

 // 创建页面报表
public static void BuildPageReportLayout(Design.Designer designer)
{
PageReport report = new PageReport();
report.Load(new StringReader(
@"<Report xmlns=""http://schemas.microsoft.com/sqlserver/reporting/2005/01/reportdefinition"">
<Body>
<Height>27.9cm</Height>
<ReportItems>
<FixedPage Name=""FixedPage1"">
<Pages>
<Page />
</Pages>
</FixedPage>
</ReportItems>
</Body>
<BottomMargin>2.5cm</BottomMargin>
<LeftMargin>2.5cm</LeftMargin>
<PageHeight>27.9cm</PageHeight>
<PageWidth>21.6cm</PageWidth>
<RightMargin>2.5cm</RightMargin>
<TopMargin>2.5cm</TopMargin>
<Width>21.6cm</Width>
</Report>")); report = LayoutBuilder.AddDataSetDataSource(report);//Adding DataSources to the PageReport object
MemoryStream reportStream = LayoutBuilder.LoadReportToStream(report);//Loading the PageReport object to a stream
reportStream.Position = 0; designer.LoadReport(XmlReader.Create(reportStream), DesignerReportType.Page);
}

3. 页面报表和RDL添加数据方法

因为页面报表和RDL报表从代码级别而言,是相同的,都被视为PageReport,所以对于页面报表和RDL报表执行的类和接口也都相同。

添加数据集采用的是绑定预先设计的字段,因为在使用过程中用户只需要使用现成的数据来设计报表,所以我们需要为报表预先绑定好可以使用的字段,代码如下:

 public static PageReport AddDataSetDataSource(PageReport report)
{
// create DataSource for the report
DataSource dataSource = new DataSource();
dataSource.Name = "Reels Database";
dataSource.ConnectionProperties.DataProvider = "DATASET";
dataSource.ConnectionProperties.ConnectString = ""; //Create DataSet with specified query and load database fields to the DataSet
DataSet dataSet = new DataSet();
Query query = new Query();
dataSet.Name = "Sample DataSet";
query.DataSourceName = "Reels Database";
query.CommandType = QueryCommandType.Text;
query.CommandText = "";
dataSet.Query = query;
String[] fieldsList = new String[] { "MoviedID", "Title", "YearReleased", "MPAA" };
foreach (string fieldName in fieldsList)
{
Field field = new Field(fieldName, fieldName, null);
dataSet.Fields.Add(field);
}
//create report definition with specified DataSet and DataSource
report.Report.DataSources.Add(dataSource);
report.Report.DataSets.Add(dataSet);
return report;
}

4. 创建区域报表及添加数据:

区域报表的创建方式与页面报表类似,采用字符串读取的形式,并直接添加数据字段。

 public static void BuildSectionReportLayout(Design.Designer designer)
{
// 空白区域报表
string rpx = "<?xml version=\"1.0\" encoding=\"utf-8\"?> <ActiveReportsLayout Version=\"3.2\" PrintWidth=\"9360\" DocumentName=\"ActiveReports Document\" ScriptLang=\"C#\" MasterReport=\"0\"> <StyleSheet> <Style Name=\"Normal\" Value=\"font-family: Arial; font-style: normal; text-decoration: none; font-weight: normal; font-size: 10pt; color: Black; text-align: left; vertical-align: top; ddo-char-set: 1\" /> <Style Name=\"Heading1\" Value=\"font-family: Arial; font-size: 16pt; font-style: normal; font-weight: bold\" /> <Style Name=\"Heading2\" Value=\"font-family: Times New Roman; font-size: 14pt; font-style: italic; font-weight: bold\" /> <Style Name=\"Heading3\" Value=\"font-family: Arial; font-size: 13pt; font-style: normal; font-weight: bold\" /> </StyleSheet> <Sections> <Section Type=\"PageHeader\" Name=\"PageHeader1\" Height=\"360\" BackColor=\"16777215\" /> <Section Type=\"Detail\" Name=\"Detail1\" Height=\"2880\" BackColor=\"16777215\" /> <Section Type=\"PageFooter\" Name=\"PageFooter1\" Height=\"360\" BackColor=\"16777215\" /> </Sections> <ReportComponentTray /> <PageSettings /> <Parameters /> </ActiveReportsLayout>"; // 区域报表数据源结构
System.Data.DataTable dt = new System.Data.DataTable();
dt.Columns.Add("Col1");
dt.Columns.Add("Col2");
dt.Columns.Add("Col3"); designer.Report = null; // 加载区域报表到设计器
designer.LoadReport(XmlReader.Create(LayoutBuilder.CovertStringToStream(rpx)), DesignerReportType.Section); // 设置区域报表数据源
SectionReport sr2 = designer.Report as SectionReport;
sr2.DataSource = dt;
}

5. 修改ReportsForm_Load 方法

 LayoutBuilder.BuildRdlReportLayout(this.reportDesigner);

这样打开设计器之后,则会呈现带字段的数据集,当用户可以直接使用数据集字段,设计满足需求的报表了,当用户设计完成可能需要预览报表,这样就需要为报表返回实际的数据了。

首先在报表设计器中添加“预览”按钮

        // 添加预览报表菜单
fileMenu.DropDownItems.Add(new ToolStripMenuItem("预览", null, new EventHandler(OnViewReport)));

实现预览方法,将当前设计的报表传给ReportViewer:

 private void OnViewReport(object sender, EventArgs e)
{
ReportViewer viewer = new ReportViewer();
viewer.Report = reportDesigner.Report;
viewer.ReportType = reportDesigner.ReportType;
viewer.ShowDialog();
}
获取到保镖对象后,通过LocateDataSource来绑定字段:
switch (ReportType)
{
case DesignerReportType.Page:
PageReport report1 = Report as PageReport; viewer1.LoadDocument(report1.Document);
break;
case DesignerReportType.Rdl:
PageReport report2 = Report as PageReport;
PageDocument reportD = new PageDocument(report2);
reportD.LocateDataSource += new LocateDataSourceEventHandler(LoadDataSet);
viewer1.LoadDocument(reportD);
break;
其中我们在DataSet中使用了DataRelation 对象,用来创建Table之间的关系,但是AR对DataRelation的支持只限于父级数据的访问。 

访问父数据表的字段时,字段的前缀应该为合适的数据表的关系名称,使用“.”进行分割。举例说明,有一个数据表OrderDetails作为子表关联到数据表Orders,两个数据表之间的关系名称为Orders_OrderDetails。可以使用下面的语法访问父数据表的字段OrderDate:Orders_OrderDetails.OrderDate

使用同样的语法可以访问嵌套多层的数据表字段。如,上例中的数据表Orders也存在父数据表Customers,关系名称为Customers_orders。命令行文本中指定数据表OrderDetails为主表,使用下面的语法访问父数据表的字段CustomerName:Customers_Orders.Orders_OrderDetails.CustomerName

注:当字段名称和关系使用相同名称时会发生错误,暂时不支持。

private void LoadDataSet(object sender, LocateDataSourceEventArgs args)
{
string constr = @"Provider=sqloledb; password=xA123456;data source=10.32.2.28;initial catalog=NWind_CHS;user id=sa;"; //此处修改为AR的测试数据库 // 创建DataSet
DataSet myDataSet = new DataSet();
//string connStr = Properties.Resources.ConnectionString;
OleDbConnection conn = new OleDbConnection(constr);
DataTable[] myDataTables = new DataTable[3];
myDataTables[0] = new DataTable(Constants.SaleTableName);
myDataTables[1] = new DataTable(Constants.SaleDetailsTableName);
myDataTables[2] = new DataTable(Constants.CustomerTableName); //创建DataTable
myDataSet.Tables.Add(myDataTables[0]);
OleDbCommand cmd1 = new OleDbCommand(Constants.cmdText1, conn);
OleDbDataAdapter oleAdapter1 = new OleDbDataAdapter(cmd1);
oleAdapter1.Fill(myDataSet.Tables[0]); //为Table 添加数据
myDataSet.Tables.Add(myDataTables[1]);
OleDbCommand cmd2 = new OleDbCommand(Constants.cmdText2, conn);
OleDbDataAdapter oleAdapter2 = new OleDbDataAdapter(cmd2);
oleAdapter2.Fill(myDataSet.Tables[1]); //为Table 添加数据
myDataSet.Tables.Add(myDataTables[2]);
OleDbCommand cmd3 = new OleDbCommand(Constants.cmdText3, conn);
OleDbDataAdapter oleAdapter3 = new OleDbDataAdapter(cmd3);
oleAdapter3.Fill(myDataSet.Tables[2]); //创建 “DataRelation Customers_Orders”
DataRelation Customers_Orders = new DataRelation("C_O",myDataSet.Tables[2].Columns["客户ID"],
myDataSet.Tables[0].Columns["客户ID"] );
myDataSet.Relations.Add(Customers_Orders); //创建 “DataRelation ”
DataRelation Orders_OrderDetails = new DataRelation("O_OD ", myDataSet.Tables[0].Columns["订单ID"],
myDataSet.Tables[1].Columns["订单ID"]);
myDataSet.Relations.Add(Orders_OrderDetails); //返回从表数据
args.Data = myDataSet.Tables[0];

到这里本篇内容就已经讲述完了,主要对于开发CRM系统的一些用户数据处理,和如何绑定到报表中进行了讲述,希望对大家有所帮助。
Demo 下载






如何在CRM系统中集成ActiveReports最终报表设计器的更多相关文章

  1. 机房收费系统中的Grid++Report报表设计器的应用

    在进行账单查询功能的时候我应用了Grid++Report报表设计器,下面我就为大家介绍一下,还望大家多多指点. 首先,在Grid++Report报表设计器中进行报表界面的设置.在属性编辑窗口中这里对报 ...

  2. ActiveReports最终报表设计器本地化方法介绍

    ActiveReports UI界面中的所有字符信息.错误提示信息.以及一些logo.图像资源,都能够通过运行batch文件来本地化.本文主要介绍资源本地化的具体步骤: 1. 资源目录 所有可本地化的 ...

  3. 创建您的 ActiveReports Web端在线报表设计器

    概述 ActiveReports Web端在线报表设计器已经正式上线!看到它这么帅气.实用,你是不是也想自己动手创建一个? 现在我们就来教您,如何创建一个简单的 ActiveReports Web端在 ...

  4. 如何在win7系统中安装redis

    转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/92.html?1455871954 如何在win7系统中安装redis​ ...

  5. 如何在CentOS系统中安装配置SNMP服务

    CentOS(Community Enterprise Operating System,中文意思是:社区企业操作系统)是Linux发行版之一,现在有一大部分服务器在使用此操作系统:SNMP(简单网络 ...

  6. 解析大型.NET ERP系统核心组件 查询设计器 报表设计器 窗体设计器 工作流设计器 任务计划设计器

    企业管理软件包含一些公共的组件,这些基础的组件在每个新项目立项阶段就必须考虑.核心的稳定不变功能,方便系统开发与维护,也为系统二次开发提供了诸多便利.比如通用权限管理系统,通用附件管理,通用查询等组件 ...

  7. 在网页中编辑报表的报表设计器Stimulsoft Reports Designer.Web报表控件

    Stimulsoft Reports Designer.Web报表控件是一款网页报表设计器.您想在网页中编辑您的报表吗?现在是可能的! Stimulsoft Reports Designer.Web ...

  8. 如何在Windows系统中配置Mysql群集(Mysql Cluster)

    MySQL群集技术在分布式系统中为MySQL数据提供了冗余特性,增强了安全性,使得单个MySQL服务器故障不会对系统产生巨大的负面效应,系统的稳定性得到保障. Mysql群集(Cluster)简介 M ...

  9. 手把手教你如何在Ubuntu系统中安装Pycharm

    前几天带大家一起安装了Ubuntu14.04系统,没来得及上车的伙伴可以戳这篇文章:手把手教你在VMware虚拟机中安装Ubuntu14.04系统.今天小编带大家一起在Ubuntu14.04中安装Py ...

随机推荐

  1. 找出一个二维数组中的"鞍点",即该位置上的元素在该行中最大,在该列中最小(也可能没有"鞍点"),打印有关信息.(提示:注意特殊情况:没鞍点或多个鞍点)

    #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { ][] = {}; ;i < ...

  2. zabbix server配置文件

    这样的错误日志,并且在web端也没有画出图来. 解决方法: ①编辑zabbix服务器端的配置文件/etc/zabbix/zabbix_server.conf找到"Timeout"把 ...

  3. oracle方案是什么?

    某用户拥有的所有的数据库对象的逻辑集合,就叫方案:方案在名称上和用户名是相同的. 比如有一个Oracle"用户"叫scott,那么一般称Scott用户所拥有的所有数据库对象的集合叫 ...

  4. 在Xcode 6 beta里编译Cocos2d-x iOS项目时失败

    转载 在Xcode 6 beta里编译Cocos2d-x iOS项目时可能会失败,提示如下错误: Undefined symbols for architecture i386: "_fwr ...

  5. unity3d多线程坑

    单独起了一个线程来处理网络相关操作,比较常规的做法.本身没啥特别的东西,碰到了一个不大不小的坑折腾了好久,记录下来吧. 简单的说就是子线程中抛出的异常,如果没有catch的话,会导致子线程悄无声息的退 ...

  6. <<你最喜欢做什么--兴趣问题清单>>总结

    二.测试作业 你最喜欢做什么--兴趣问题清单 •根据迄今为止已有的经历,你真正喜欢从事的工作是什么?   目前还没有接触工作,就工作而言,凭自己所学的本领和技术去工作,我认为我会喜欢我所做的工作 •休 ...

  7. Spring 3种注入方式

    spring的三种注入方式: 接口注入(不推荐) getter,setter方式注入(比较常用) 构造器注入(死的应用) 关于getter和setter方式的注入: autowire="de ...

  8. Linux内核--网络栈实现分析(四)--网络层之IP协议(上)

    本文分析基于Linux Kernel 1.2.13 原创作品,转载请标明http://blog.csdn.net/yming0221/article/details/7514017 更多请看专栏,地址 ...

  9. hibernate常用API详解

    根据个人使用Hibernate的经验,介绍一下Hibernate的多种不同的查询和CUD操作,这些东西在日常开发中非常常用,希望对大家有所帮助. 以下示例均以两张表为例:member和userinfo ...

  10. Sphinx : 高性能SQL全文检索引擎

    Sphinx的特点 快速创建索引:3分钟左右即可创建近100万条记录的索引,并且采用了增量索引的方式,重建索引非常迅速. 闪电般的检索速度:尽管是1千万条的大数据量,查询数据的速度也在毫秒级以上,2- ...