水晶报表教程:动态传递参数

使用教程 | 作者:besy | 2014-04-08 10:13:08| 阅读 0 有用 (0) 评论 (0) 收藏


概述:本文跟大家分享了如何让水晶报表动态传递参数并形成报表。

我最近做了个小东西,要用到打印--数据输出,于是选择了水晶报表。 我用的是水晶报表VS2010。对于在报表中连接数据库,相对比较简单,下面想跟大家分享下如何让报表动态传递参数,然后形成报表文件,这可能在实际工作地很多情况下,都用得到。

我用到的前台技术是ASP.NET。这是.NET下关于水晶报表参数的一些API:parameterfields类、parameterfield类、parameterdiscretevalue类、parameterrangevalue类等。关于这些API的一些具体的用法,可以参考MSDN。

还要注意使用这些类的时候,要加上如下命名空间:

using CrystalDecisions.CrystalReports .Engine ;
using CrystalDecisions.Shared ;

下面来看看具体的代码使用:

 #region--------------向报表传递参数--------------------

    ParameterFields paraFields =new ParameterFields ();
ParameterField[] paraField=new ParameterField [8];
ParameterDiscreteValue[] discreteValue=new ParameterDiscreteValue [8];
ParameterRangeValue rangeValue=new ParameterRangeValue ();

    paraField[0]=new ParameterField ();
paraField[0].ParameterFieldName ="Name";
discreteValue[0]=new ParameterDiscreteValue ();
discreteValue[0].Value =(string)Session["Name"];
paraField[0].CurrentValues .Add (discreteValue[0]);

    paraField[1]=new ParameterField ();
paraField[1].Name ="MajorName";
discreteValue[1]=new ParameterDiscreteValue ();
discreteValue[1].Value =(string)Session["MajorName"];
paraField[1].CurrentValues .Add (discreteValue[1] );

    paraField[2]=new ParameterField ();
paraField[2].Name ="YearName";
discreteValue[2]=new ParameterDiscreteValue ();
discreteValue[2].Value =(string)Session["YearName"];
paraField[2].CurrentValues .Add (discreteValue[2]);

    paraField[3]=new ParameterField ();
paraField[3].Name ="TuitionPay";
discreteValue[3]=new ParameterDiscreteValue ();
discreteValue[3].Value =Convert.ToDecimal (Session["TuitionPay"]);
paraField[3].CurrentValues .Add (discreteValue[3]);

    paraField[4]=new ParameterField ();
paraField[4].Name ="TuitionOwed";
discreteValue[4]=new ParameterDiscreteValue ();
discreteValue[4].Value =Convert.ToDecimal (Session["TuitionOwed"]);
paraField[4].CurrentValues .Add (discreteValue[4]);

    paraField[5]=new ParameterField ();
paraField[5].Name ="Year";
discreteValue[5]=new ParameterDiscreteValue ();
discreteValue[5].Value =(string)Session["Year"];
paraField[5].CurrentValues .Add (discreteValue[5]);

    paraField[6]=new ParameterField ();
paraField[6].Name ="Month";
discreteValue[6]=new ParameterDiscreteValue ();
discreteValue[6].Value =(string)Session["Month"];
paraField[6].CurrentValues .Add (discreteValue[6]);

    paraField[7]=new ParameterField ();
paraField[7].Name ="Day";
discreteValue[7]=new ParameterDiscreteValue ();
discreteValue[7].Value =(string)Session["Day"];
paraField[7].CurrentValues .Add (discreteValue[7]);

foreach(ParameterField pf in paraField)
{
paraFields.Add (pf);
}

ReportDocument rptdoc=new ReportDocument ();
rptdoc.Load (Server.MapPath ("../agreementTest.rpt"));
this.CrystalReportViewer1.ReportSource =rptdoc;
this.CrystalReportViewer1.ParameterFieldInfo =paraFields;
this.CrystalReportViewer1 .DataBind ();
//this.CrystalReportViewer1 .RefreshReport ();
#endregion

需要说明的是,必须在水晶报表里面先创建这些参数,才可以使用(而且报表里的参数和代码里的参数保持一致)。另外就是在水晶报表10里参数创建的时候,可以选择创建离散值参数(discrete),也可以选择创建连续值参数(range),那么对应的代码中要用不同的类(parameterdiscretevalue和parameterrangevalue)。


慧都控件|提供软件技术整体解决方案

云集全球三千余款优秀控件、软件产品,提供行业领先的咨询、培训与开发服务
企业QQ:800018081|电话:023-68661681

用户评论: 您的宝贵经验,能为更多人带来帮助,登录后才能评论。
评论加载中...



    联系我们


    官方微信
    官方微博