码迷,mamicode.com
首页 > 其他好文 > 详细

rdlc报表

时间:2014-11-27 20:06:59      阅读:203      评论:0      收藏:0      [点我收藏+]

标签:des   http   io   ar   os   使用   sp   for   文件   

也是第一次接触报表这个东西。现在在我理解,报表无非就是两个内容,格式和数据。

  格式没有多少了解,就记录了,以后再续。数据的绑定和结果的显示是怎么实现的呢?

今天的主角就是rdlc这个文件和ReportViewer这个控件。先说ReportViewer,在客户端程序中它就是用来绑定数据源和显示最终的报表的。

报表文件(.rdlc)也要绑定到这个数据集,并且选择好字段。最后将报表文件(.rdlc)添加到ReportViewer控件中就完事。

     一个傻瓜式例子:

    

创建新的 Windows 窗体应用程序项目

  1. “文件”菜单上,指向“新建”,然后选择“项目”。

  2. “新建项目”对话框中的“已安装的模板”窗格中,选择“Visual C#”,然后选择“Windows 窗体应用程序”模板。根据 Visual Studio 中的启动设置,“C#”节点可能会显示在“其他语言”下。

  3. 键入项目的名称“BusinessObject”,并单击“确定”。

创建要用作数据源的业务对象

  1. “项目”菜单中选择“添加新项”。

  2. “添加新项”对话框中,选择“类”,键入文件名“BusinessObjects.cs”,然后单击“添加”。

    新文件将添加到项目并且在 Visual Studio 中自动打开。

  3. 将 BusinessObjects.cs 的默认代码替换为以下代码:

     
    using System;
    using System.Collections.Generic;
    
    // Define the Business Object "Product" with two public properties
    //    of simple datatypes.
    public class Product {
        private string m_name;
        private int m_price;
    
        public Product(string name, int price) {
            m_name = name;
            m_price = price;
        }
    
        public string Name {
            get {
                return m_name;
            }
        }
    
        public int Price {
            get {
                return m_price;
            }
        }
    }
    
    // Define Business Object "Merchant" that provides a 
    //    GetProducts method that returns a collection of 
    //    Product objects.
    
    public class Merchant {
        private List<Product> m_products;
    
        public Merchant() {
            m_products = new List<Product>();
            m_products.Add(new Product("Pen", 25));
            m_products.Add(new Product("Pencil", 30));
            m_products.Add(new Product("Notebook", 15));
        }
    
        public List<Product> GetProducts() {
            return m_products;
        }
    }
    
    
  4. “项目”菜单中,选择“生成解决方案”。这将为对象创建一个程序集,您稍后会将此程序集用作报表的数据源。

使用报表向导向项目添加报表

  1. “项目”菜单中选择“添加新项”。

  2. “添加新项”对话框中,选择“报表向导”。为报表键入名称,并单击“添加”。

    这将启动报表向导中的数据源配置向导。

  3. “选择数据源类型”页上,选择“对象”,并单击“下一步”。

  4. “选择数据对象”页中的“BusinessObject”下,展开类的层次结构,直到在列表中看到“产品”。选择“产品”,再单击“完成”。

    现在已返回到“报表向导”。请注意,新数据源对象已添加到“解决方案资源管理器”中的项目中。

  5. “数据集属性”页中的“数据源”框中,确认选中“全局”。

  6. “可用数据集”框中,确认选中“产品”。

  7. 单击“下一步”。

  8. “排列字段”页中,执行以下操作:

    1. “名称”从“可用字段”拖到“行组”框。

    2. “价格”从“可用字段”拖到“值”框。

  9. 单击两次“下一步”,然后单击“完成”。

    这将创建 .rdlc 文件并在报表设计器中将其打开。所创建的 tablix 会立即显示在设计图面中。

  10. 保存 .rdlc 文件。

向报表中添加 ReportViewer 控件

  1. 在解决方案资源管理器的“设计”视图中打开该 Windows 窗体。默认情况下,窗体名称为“Form1.cs”。

  2. “报表”组中,将“ReportViewer”图标从“工具箱”拖到窗体上。

  3. 在 ReportViewer 控件中,通过单击右上角的智能标记标志符号打开智能标记面板。

  4. “选择报表”列表中,选择刚才设计的报表。默认情况下,名称为 Report1.rdlc。请注意,将为报表中使用的每个对象数据源相应自动创建名为 ProductBindingSource 的 BindingSource 对象。

  5. 在打开的智能标记面板中,选择“在父容器中停靠”。

为 BindingSource 对象提供数据源实例

  1. 在解决方案资源管理器中,右键单击“Form1.cs”,然后选择“查看代码”。

  2. “Form1.cs”的分部类定义中,在构造函数前添加以下代码作为第一行。

     
     
    // Instantiate the Merchant class.
    private Merchant m_merchant = new Merchant();
    
  3. “Form1_Load()”方法中,在 RefreshReport 前添加下列代码作为第一行:

     
     
    // Bind the Product collection to the DataSource.
    this.ProductBindingSource.DataSource = m_merchant.GetProducts();
    

运行此应用程序

  • “F5”运行应用程序并查看报表

  

rdlc报表

标签:des   http   io   ar   os   使用   sp   for   文件   

原文地址:http://www.cnblogs.com/zhangxs/p/4126869.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!