ReportViewer

时间:2015-11-05 03:16:19

标签: c# reportviewer

我需要在报表查看器(rdlc文件)中显示客户列表(每页一个客户),以及与该客户相关的订单(在同一客户信息页面上)和注释。如何插入Tablix以便每个客户都有分页符?

这应该是它的样子:

这就是我想要在报告中添加数据的方式:

List<Customer> customers = db.Customers;

LocalReport.DataSources.Add(new ReportDataSource("Customers", customers))

public class Customer
{
    public string Name { get; set; }
    public string PhoneNumber { get; set; }
    public List<Order> Orders { get; set; }
    public List<Comment> Comments { get; set; }
}

public class Order
{
    public string Product { get; set; }
    public int Qty { get; set; }
    public decimal Price { get; set; }
}

public class Comment
{
    public string Description { get; set; }
}
编辑:也许我没有正确表达。我不知道如何在列表项上显示每个客户的订单和评论。我该如何分组?如何将DataSet设置为Sub Table(对于订单和注释)

2 个答案:

答案 0 :(得分:0)

以下MSDN页面https://msdn.microsoft.com/en-us/library/dd207058.aspx 表示如果要将分页符添加到表,矩阵或列表中的行组,请按照以下步骤操作:

  1. 在“分组”窗格中,右键单击行组,然后单击组属性
  2. 在分页符选项卡上,选择在组的每个实例之间,以在表格中的每个组实例之间添加分页符。
  3. (可选)选择同样在组的开头也在组的末尾以指定在组开始或结束时添加分页符桌子。

答案 1 :(得分:0)

我最后使用子报告:

  1. 标题(姓名和电话),子报告位置和分页符的一个重要报告

  2. 订单的一个子报表(CustomersOrders.rdlc):添加子报表参数(CustomerId)

  3. 评论的一个子报告(CustomersComments.rdlc):添加子报告参数(CustomerId)

  4. 报表呈现器窗口中的静态属性,其中包含客户列表

  5. 在报告渲染器窗口中添加SubreportProcessing处理程序:

    LocalReport.SubreportProcessing += Customers_SubreportProcessing;
    
    private void Customers_SubreportProcessing(object sender, SubreportProcessingEventArgs e)
    {
        ReportParameterInfo customerId = e.Parameters.FirstOrDefault(c => c.Name == "CustomerId");
        if (customerId== null)
            return;
    
        Customer customer = _customersList
            .FirstOrDefault(c => c.CustomerId == customerId.Values.FirstOrDefault());
    
        if (e.ReportPath == "CustomersOrders") // Name for subreport CustomersOrders.rdlc
        {
            e.DataSources.Add(new ReportDataSource("Orders", customer.Orders));
        }
        else if (e.ReportPath == "CustomersComments") // Name for subreport CustomersComments.rdlc
        {
            e.DataSources.Add(new ReportDataSource("Comments", customer.Comments));
        }
    }