如何在CRM系统中集成ActiveReports最终报表设计器

时间:2021-09-12 07:18:09

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

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

 

如何在CRM系统中集成ActiveReports最终报表设计器

1.创建RDL报表

 

使用PageReport对象,并添加属性

 公共 静态 无效 BuildRdlReportLayout(Design.Designer设计师)
{
PageReport报告= PageReport();

report.Report.Body.Height = “5厘米” ;
report.Report.Width = “20厘米” ;

report.Load( StringReader(report.ToRdlString()));

//报告= LayoutBuilder.AddDataSetDataSource(报告); //添加数据源到PageReport对象
报告= LayoutBuilder.addDataSet(报告);
MemoryStream的reportStream = LayoutBuilder.LoadReportToStream(报告); //加载PageReport对象到流
reportStream.Position = 0;


designer.LoadReport(XmlReader.Create(reportStream),DesignerReportType.Page);
}

 

2.创建页面报表

 

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

 //创建页面报表        公共 静态 无效 BuildPageReportLayout(Design.Designer设计师)        {            PageReport报告=  PageReport();            report.Load( StringReader(               @“<报告的xmlns =” “http://schemas.microsoft.com/sqlserver/reporting/2005/01/reportdefinition” “>                <BODY>                    <高程>27.9厘米</高度>                    <ReportItems>                        <固定页面名称=“ ”FixedPage1“ ”>                            <页>                                <页/>                            </页>                        </固定页面>                    </ ReportItems>                </ BODY>                <BottomMargin>2.5厘米</ BottomMargin>                <LEFTMARGIN>2.5厘米</ LEFTMARGIN>                <PageHeight>27.9厘米</ PageHeight>                <页宽>21.6厘米</页宽>                <RightMargin>2.5厘米</ RightMargin>                <TOPMARGIN>2.5厘米</ TOPMARGIN>                <宽度>21.6厘米</宽度>                  </报告>“ ));            报告= LayoutBuilder.AddDataSetDataSource(报告); //添加数据源到PageReport对象             的MemoryStream reportStream = LayoutBuilder.LoadReportToStream(报告); //加载PageReport对象到流            reportStream.Position = 0;            designer.LoadReport(XmlReader.Create(reportStream),DesignerReportType.Page);        }

 

 

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

 

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

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

 公共 静态 PageReport AddDataSetDataSource(PageReport报告)        {            //为报表创建数据源             数据源数据源= 的数据源();            dataSource.Name = “卷筒数据库” ;            dataSource.ConnectionProperties.DataProvider = “DATASET” ;            dataSource.ConnectionProperties.ConnectString = “” ;            //使用指定的查询和负载的数据库字段的数据集创建数据集             的数据集的数据集= 的DataSet();            查询查询= 新的查询();            dataSet.Name = “样本数据集” ;            query.DataSourceName = “卷筒数据库” ;            query.CommandType = QueryCommandType.Text;            query.CommandText = “” ;            dataSet.Query =查询;            的String [] = fieldsList 的String [] { “MoviedID” ,“标题” ,“YearReleased” ,“美国电影协会” };             的foreach字符串字段名 fieldsList)            {                场场= 新的领域(字段名,字段名,);                dataSet.Fields.Add(场);            }            //创建指定的DataSet和DataSource报表定义            report.Report.DataSources.Add(数据源);            report.Report.DataSets.Add(数据集);            返回报告;        }

 

 

 

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

 

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

 公共 静态 无效 BuildSectionReportLayout(Design.Designer设计师)        {            //空白区域报表            字符串 RPX = “<?XML版本= \”1.0 \“编码= \”UTF-8 \“?> <ActiveReportsLayout版本= \”3.2 \“PrintWidth = \”9360 \“DocumentName = \”的ActiveReports文档\“ScriptLang = \”C#\“MasterReport = \”0 \“> <样式表> <样式名称= \”正常\“VALUE = \”FONT-FAMILY:宋体; 字体风格:正常; 文字修饰:无; 字体重量:正常; 字体大小:10PT; 颜色:黑色; 文本对齐:左; 垂直对齐:首位; DDO-字符集:1 \“/> <样式名称= \”标题1 \“值= \”FONT-FAMILY:宋体; 字体大小:16PT; 字体风格:正常; 字体重量:大胆的\“/> <样式名称= \”Heading2 \“VALUE = \”FONT-FAMILY:宋体; 字体大小:14pt; 字体样式:斜体; 字体重量:大胆的\“/> <样式名称= \”Heading3 \“VALUE = \”FONT-FAMILY:宋体; 字体大小:13pt; 字体风格:正常; 字体重量:大胆的\“/> </样式表> <节> <科类= \”PageHeader \“NAME = \”PageHeader1 \“HEIGHT = \”360 \“背景色= \”16777215 \“/> <节类型= \“详细信息\”NAME = \“Detail1 \”HEIGHT = \“2880 \”背景色= \“16777215 \”/> <部分类型= \“PageFooter \”NAME = \“PageFooter1 \”HEIGHT = \“ 360 \“背景色= \”16777215 \“/> </节> <ReportComponentTray /> <PageSettings /> <参数/> </ ActiveReportsLayout>” ;            //区域报表数据源结构             System.Data.DataTable DT =  System.Data.DataTable();            dt.Columns.Add(“COL1”);            dt.Columns.Add(“col2的”);            dt.Columns.Add(“COL3”);            designer.Report =  ;            //加载区域报表到设计器            designer.LoadReport(XmlReader.Create(LayoutBuilder.CovertStringToStream(RPX)),DesignerReportType.Section);            //设置区域报表数据源             SectionReport SR2 = designer.Report  SectionReport;            sr2.DataSource = DT;        }

 

5.修改ReportsForm_Load方法

LayoutBuilder.BuildRdlReportLayout( .reportDesigner);

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

 

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

 
 

如何在CRM系统中集成ActiveReports最终报表设计器

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

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

 
 私人 无效 OnViewReport(对象发件人,EventArgs的发送)        {            观众的ReportViewer = 的ReportViewer();            viewer.Report = reportDesigner.Report;            viewer.ReportType = reportDesigner.ReportType;            viewer.ShowDialog();        }
 
 
获取到保镖对象后,通过LocateDataSource来绑定字段:
开关(的ReportType)            {                案例 DesignerReportType.Page:                    PageReport报告1 =报告 PageReport;                                       viewer1.LoadDocument(report1.Document);                    打破 ;                 案例 DesignerReportType.Rdl:                    PageReport报告2 =报告 PageReport;                    PageDocument reportD =  PageDocument(报告2);                    reportD.LocateDataSource + =  LocateDataSourceEventHandler(LoadDataSet);                    viewer1.LoadDocument(reportD);                    突破 ;        
 
其中我们在数据集中使用了的DataRelation对象,用来创建Table之间的关系,但是AR对DataRelation的支持只限于父级数据的访问。 

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

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

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

 
私人 无效 LoadDataSet(对象发件人,LocateDataSourceEventArgs参数)        {           字符串构造= @“提供程序= SQLOLEDB;密码= xA123456;数据源= 10.32.2.28;初始目录= NWind_CHS;用户ID = SA;” ;                       //此处修改为AR的测试数据库           //创建DataSet中            的DataSet myDataSet = 的DataSet();            //字符串connStr = Properties.Resources.ConnectionString;            OleDbConnection的康恩= 的OleDbConnection(构造);           数据表[] = myDataTables 的DataTable [3];           myDataTables [0] = 的DataTable(Constants.SaleTableName);           myDataTables [1] = 的DataTable(Constants.SaleDetailsTableName);           myDataTables [2] = 的DataTable(Constants.CustomerTableName);                       //创建数据表               myDataSet.Tables.Add(myDataTables [0]);           OleDbCommand的CMD1 = 的OleDbCommand(Constants.cmdText1,康涅狄格州);           OleDbDataAdapter的oleAdapter1 =  OleDbDataAdapter的(CMD1);           oleAdapter1.Fill(myDataSet.Tables [0]);           //为表添加数据           myDataSet.Tables.Add(myDataTables [1]);           OleDbCommand的CMD2 = 的OleDbCommand(Constants.cmdText2,康涅狄格州);           OleDbDataAdapter的oleAdapter2 =  OleDbDataAdapter的(CMD2);           oleAdapter2.Fill(myDataSet.Tables [1]);           //为表添加数据           myDataSet.Tables.Add(myDataTables [2]);           OleDbCommand的CMD3 = 的OleDbCommand(Constants.cmdText3,康涅狄格州);           OleDbDataAdapter的oleAdapter3 =  OleDbDataAdapter的(CMD3);           oleAdapter3.Fill(myDataSet.Tables [2]);           //创建“的DataRelation Customers_Orders”            的DataRelation Customers_Orders = 的DataRelation(“C_O”,myDataSet.Tables [2] .Columns [ “客户ID” ]               myDataSet.Tables [0] .Columns [ “客户ID” ]);           myDataSet.Relations.Add(Customers_Orders);                      //创建“的DataRelation”            的DataRelation Orders_OrderDetails = 的DataRelation(“O_OD”,myDataSet.Tables [0] .Columns [ “订单ID” ]                              myDataSet.Tables [1] .Columns [ “订单ID” ]);           myDataSet.Relations.Add(Orders_OrderDetails);                                     //返回从表数据             args.Data = myDataSet.Tables [0];
 
 

如何在CRM系统中集成ActiveReports最终报表设计器

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