RDLC是微软推出的自家的报表软件,虽然没有一些第三方的报表软件强大好用,但是作为VisualStudio集成的报表工具,在客户要求不高的情况下还是非常值得一用的,本文将介绍通过General代码生成器和General框架快速的开发一个报表程序。

第一步、生成RDLC报表文件

传统的开发方式是通过VisualStudio创建RDLC报表文件,但这种方式效率很慢,不适合大量报表开发,而通过General代码生成器可以快速的大量生成报表格式,大大提高开发效率,并且生成的报表文件可以在VisualStudio中打开继续修改,并不影响复杂报表格式的制作。用General代码生成器生成RDLC报表文件的过程如下图所示:

生成之后保存为后缀名为.rdlc的报表文件。

第二步、制作报表查看器

如果是WinForm程序,这一步非常简单,只需要新建一个窗体,再从工具箱中将ReportViewer控件拖到窗体上并设置Dock = Fill就可以了。如果工具箱中没有找到ReportViewer,需要手动添加,还有可能工具箱里没有ReportViewer,但手动添加时ReportViewer项已经勾选了,那就需要取消勾选,然后再打开再勾选添加。

RDLC可以通过添加数据集的方式给报表输送数据,但这种方式灵活性太差不适合项目要求。这里,我们采用动态方式给报表输送数据,并做成通用的报表查看器,这样再增加报表时,只需生成新的RDLC文件并指定给报表查看器,再输送指定的数据即可。

所以我们修改报表查看器的后台代码:

 1 using System;
 2 using System.Collections.Generic;
 3 using System.ComponentModel;
 4 using System.Data;
 5 using System.Drawing;
 6 using System.Text;
 7 using System.Windows.Forms;
 8  
 9 namespace Sample.Market.WinForm
 {
     public partial class FrmReport : Form
     {
         /// <summary>
         /// RDLC文件路径,支持相对路径
         /// </summary>
         public string ReportPath { get; set; }
  
         /// <summary>
         /// 报表数据源
         /// </summary>
         public DataTable DataSource { get; set; }
  
         public FrmReport()
         {
             InitializeComponent();
         }
  
         private void FrmReport_Load(object sender, EventArgs e)
         {
             // 显示报表代码
             reportViewer1.ProcessingMode = Microsoft.Reporting.WinForms.ProcessingMode.Local;
             reportViewer1.LocalReport.ReportPath = this.ReportPath;
             reportViewer1.LocalReport.DataSources.Clear();
             reportViewer1.LocalReport.DataSources.Add(new Microsoft.Reporting.WinForms.ReportDataSource("DataSet1", this.DataSource));
             reportViewer1.RefreshReport();
         }
     }
 }

而调用报表查看器打开报表的代码如下:

             DataTable dt = goodsLogic.GetAllData();
             FrmReport frm = new FrmReport();
             frm.ReportPath = "Reports\\GoodsReport.rdlc";
             frm.DataSource = dt;
             frm.Show();

GoodsLogic的GetAllData方法代码如下:

1         /// <summary>

         /// 获取所有数据
         /// </summary>
         /// <returns></returns>
         public DataTable GetAllData()
         {
             return DataManager.Default.CreateQuery<Goods>().ToTable();
         }

可以看到,通过General框架很方便的取到报表数据,再调用报表查看器显示报表,代码非常简单,最终显示结果如下:

如果需要修改报表的格式,比如列宽、标题等,可以将.rdlc文件在VisualStudio中打开进行编辑,或是在代码生成器中修改模板重新生成报表文件。

大家可能还注意到一个问题,就是报表的列头在下一页不见了,要让列头在每页都显示需要对报表文件进行如下修改:

你可能会觉得每一个报表都这样修改太麻烦,那好,我们来修改模板。

先使用文本比较工具比较一下修改前和修改后的.rdlc文件,发现差别只有一行:

那我们相应的在模板中也加入这一行:

重新生成报表文件,再打开报表,可以看到每页都可以显示列头了。

General代码生成器请移步这里下载:

General框架及代码生成器下载地址

利用General框架开发RDLC报表的更多相关文章

  1. 利用General框架进行三层架构开发

    三层架构是企业信息管理系统中一种比较流行的架构方式,如大家所知,三层架构将信息系统分为数据访问层(DAL).业务逻辑层(BLL).界面表示层(UI)三部分,三层架构的好处是根据系统中代码所处的层次将系 ...

  2. 利用CXF框架开发webservice

    开发服务端代码 1. web.xml文件中添加cxf的servlet 2. 定义接口 @WebService(targetNamespace="http://UserInfo.ws.com& ...

  3. 利用SSH框架开发时遇到的各种Bug及解决方法

    .hibernate自动生成的配置文件 hibernate.cfg.xml 有时候是有问题的,会出现 org.hibernate.HibernateException: Could not parse ...

  4. 基于vs2015的rdlc报表运行环境部署

    先说明一下,rdlc报表是由visual studio来支持的,不是FM. 本次项目采用的是vs2015开发的,当中使用了ReportViewer报表. 两种方式可以支持开发rdlc报表环境: 1)在 ...

  5. 会员管理系统的设计和开发(2)-- RDLC报表的设计及动态加载

    在上篇<会员管理系统的设计和开发(1)>介绍了关于会员系统的一些总体设计思路和要点,经过一段时间开发,软件终于完成并发布.在这期间,碰到了不少技术难点,并积累了不少开发心得和经验,本篇继续 ...

  6. 利用JasperReport+iReport进行Web报表开发

    用JasperReport+iReport进行Web报表开发 序言 在非常多实际的项目里,报表都是当中十分重要的组成部分,比如把查询结果以报表的形式呈现出来.这里所提到的报表可不是简单的二维表,而是拥 ...

  7. ReportViewer,RDLC 报表开发之个性化样式

    原文:ReportViewer,RDLC 报表开发之个性化样式 报表开发中,客户对样式提出了要求: 1.工具栏上显示每页条数 2.只导出Excel,不需要下拉菜单. 3.报表上显示的图表,分页时,每页 ...

  8. 第十二章 Odoo 12开发之报表和服务端 QWeb

    报表是业务应用非常有价值的功能,内置的 QWeb 引擎是报表的默认引擎.使用 QWeb 模板设计的报表可生成 HTML 文件并被转化成 PDF.也就是说我们可以很便捷地利用已学习的 QWeb 知识,应 ...

  9. 基于MVC4+EasyUI的Web开发框架经验总结(15)--在MVC项目中使用RDLC报表

    RDLC是一个不错的报表,有着比较不错的设计模式和展现效果,在我的Winform开发里面,使用RDLC也是一个比较方便操作,如可以参考文章<DevExpress的XtraReport和微软RDL ...

随机推荐

  1. python--关于if __name__==__main__的解释

    在解释之前首先我们看下__name__这个变量存的是什么: #!/usr/bin/env python # -*- coding:utf-8 -*- print(__name__) 结果: __mai ...

  2. 分布式_理论_04_ 3PC

    一.前言 五.参考资料 1.分布式理论(四)—— 一致性协议之 3PC 2.分布式理论(四) - 3PC协议 3.

  3. 16_游戏编程模式ServiceLocator 服务定位

    ####简单说,就是某个系统作为一个服务,对全局系统可见. Service Locator (服务定位) ``` //简单粗暴的代码, 使用声音系统 // Use a static class? Au ...

  4. uva10943(隔板法)

    很裸的隔板法. 引用一下维基上对隔板法的解释: 现在有10个球,要放进3个盒子里 ●●●●●●●●●● 隔2个板子,把10个球被隔开成3个部份 ●|●|●●●●●●●●.●|●●|●●●●●●●.●| ...

  5. linux 下安装rar解压

    在liunx下原本是不支持rar文件的,需要安装liunx下的winrar版本,操作如下 wget http://www.rarsoft.com/rar/rarlinux-4.0.1.tar.gz t ...

  6. C#面向对象(二):封装和继承

    前文链接:C#面向对象(一):明确几个简单的概念作为开胃菜 面向对象开发有三大特性(特点 / 特征) : 封装, 继承, 多态.我们今天主要讨论封装和继承,多态会在下篇中讨论. 一.封装: 所谓封装, ...

  7. celery 停止执行中 task

    目录 原因 解决过程 原因 因为最近项目需求中需要提供对异步执行任务终止的功能,所以在寻找停止celery task任务的方法.这种需求以前没有碰到过,所以,只能求助于百度和google,但是找遍了资 ...

  8. CommonJS 规范

    CommonJS 是以在浏览器环境之外构建 JavaScript 生态系统为目标而产生的项目,比如在服务器和桌面环境中. 这个项目最开始是由 Mozilla 的工程师 Kevin Dangoor 在2 ...

  9. 高性能服务器架构 的几个注意点 (High-Performance Server Architecture)

    High-Performance Server Architecture 高性能服务器架构 来源:http://pl.atyp.us/content/tech/servers.html译文来源:htt ...

  10. ntp 配置 autokey 功能【摘录】

    摘录于ntp官网:http://support.ntp.org/bin/view/Support/ConfiguringAutokey 6.7. Autokey Configuration for N ...