• RDLC子报表


    本文转载自:http://www.cnblogs.com/wjbobo/archive/2012/03/13/2362115.html

    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));

    }

    一路走来,一切都在改变,唯一不变的是心中的那份执着.
  • 相关阅读:
    Bootstrap组件福利篇 网址
    <a>标签中的href="javascript:;"
    HTTP请求上下文之终结:HttpContext类
    数据库分离 附加 sqlserver
    C#中三层架构UI、BLL、DAL、Model实际操作(转)
    比较好的网上的sqlserver读书笔记
    ORACLE重建索引详解
    SQL Server遍历表的几种方法(转)
    提高数据库操作的效率(转)
    哈希表Hashtable与字典表Dictionary<K,V>的比较。
  • 原文地址:https://www.cnblogs.com/wpcnblog/p/2672254.html
Copyright © 2020-2023  润新知