RDLC报表系统--------子报表

RDLC子报表主要设置:

    1 .先添加报表控件,在控件中拉入报表的表格Table 控件,在报表工具栏中拖入子报表控件到Table的某个单元格.

    2 .在子报表控件上右键子报表属性,选择选项卡常规-名称 添加子报表的名称 可自定义,将此报表用做子报表       中添加 已存在的报表名称,例如SaleMonthReport 不需要加.rdlc 后缀名。   

   3.选择参数选项卡,添加参数(参数可以使主报表的数据集内容,参数等) 名称可以自定义(注意:自定义的名称必须和子报表参数同名,并且在子报表添加 参数后 在测试,否则会报 本地报表呈现错误,value 值不能为Null的错误),值为数据集值、参数、内置字段、固定值 等。

到此 基本子报表配置完成。后面通过代码注册子报表   

  4.在aspx后台代码中 其他代码和普通代码类似,主要注册主报表的 SubReportProcessing 事件

ReportViewer1.LocalReport.SubreportProcessing += new     SubreportProcessingEventHandler(LocalReport_SubreportProcessing);  

   5.在LocalReport_SubreportProcessing 中添加子报表的数据源

   这里通过 string fname=e.Parameters["fname"].Values[0]; 取得子报表参数值,这里根据参数值 取得报表的数据(还有一种方法是这里不适用参数取子报表的数据,将所有的数据全部取出,然后报表会根据参数自动显示符合参数的数据内容,当数据量庞大时,效率不高) .

Datatable dtDetail=new class1().getModelByName(fname); //这个最好写在外面,为什么大家应该知道,因为有多少条主报表数据,子报表就会循环多少次。

 e.DataSources.Add(new Microsoft.Reporting.WebForms.ReportDataSource("dtDetail", dtDetail)); //添加子报表的数据

 

 

完整代码:

ReportViewer1.Visible=true;         

ReportViewer1.LocalReport.DataSources.Clear();            

ReportViewer1.LocalReport.DataSources.Add(new ReportDataSource("DataSet1", dtInfo));  

ReportViewer1.LocalReport.SubreportProcessing += new     SubreportProcessingEventHandler(LocalReport_SubreportProcessing);           

ReportViewer1.LocalReport.Refresh();

 

 

 void LocalReport_SubreportProcessing(object sender, SubreportProcessingEventArgs e)         {

  string fname=e.Parameters["fname"].Values[0];

  Datatable dtDetail=new class1().getModelByName(fname);

  e.DataSources.Add(new Microsoft.Reporting.WebForms.ReportDataSource("dtDetail", dtDetail));

}

 

posted @ 2012-02-21 23:12  凤老三  阅读(2563)  评论(8编辑  收藏  举报