关于vs2010下使用水晶报表了解情况记录如下:

1.首先vs2010不再自带水晶报表控件了,需要下载安装vs2010配套的水晶报表控件:CRforVS_13_0。这个控件安装很简单,基本上都选择默认设置就可以了。

2.安装之后,再在vs2010中添加新项,选中reporting,下面就有CrystalReports的选项了,这个就是水晶报表文件。

3.新建一个CrystalReports文件,vs2010会弹出一个水晶报表模版生成向导,可以根据向导指示,一步一步的生成自己需要的报表文件。这里我选择了标准模式。

4.根据向导的数据库连接提示,我选择了oracle服务器连接,使水晶报表与数据库连接起来,只需要按要求输入服务名,用户和密码,水晶报表模版就会自己连接上oracle。

5.然后选择需要的表或者视图,并选择相应的字段,(我跳过了后面的分组和过滤字段的设置),然后选择报表样式,水晶报表就会为你自动生成一个默认的模版。

你可以在此模版上进一步进行样式的优化调整,包括增加合并,求和等等高级操作。

6.至此,模版制作完成,现在开始写代码。

新建一个webform窗体,并在工具箱中选择报表设计,拖放一个CrystalReportViewer控件到页面上,这个就是水晶报表的web控件,有了它就可以轻松实现很多复杂的功能了。

7.可以根据自己的需求通过控制该控件的属性来控制控件的显示效果。

如:

HasPrintButton="False" //不显示打印功能按钮

HasCrystalLogo="False" //不显示水晶报表logo

HasDrilldownTabs="False" //不显示下载按钮

HasDrillUpButton="False" //不显示上传按钮

HasGotoPageButton="False" //不显示转跳按钮

ToolPanelView="None" //不显示工具栏

HasToggleGroupTreeButton="false" // 不显示水晶报表树按钮。

8.那么如何让这个水晶报表在页面上跑起来呢?下面是相关的代码

首先需要说明的是,水晶报表和众多报表控件一样有pull模式和push模式的区别。所谓的pull模式就是在模版中指定数据源,并通过模版直接取得数据并显示到控件上的模式,也是我正在使用的模式。push模式,是自己在程序中组织数据源,并推送给水晶报表模版,显示在控件上的模式,属于高级应用,更强大更灵活,当然自己也需要写更多的代码。

今天这里主要将简单好用的pull模式。

首先,初始化水晶报表类并装载好需要的模版。

  1. //找到水晶报表模版,我的水晶报表是放在web系统根目录下的WebReport文件夹中的,
  2. string MasterplateName = "test.rpt";
  3. string reportPath = Server.MapPath(Request.ApplicationPath + "/WebReport/" + MasterplateName);
  4. ReportDocument myReport = new ReportDocument();
  5. myReport.Load(reportPath);

接下来,需要重新为模版的数据库连接指定连接串防止,水晶报表连接不到数据库

  1. //定义水晶报表的数据库连接信息 
  2. ConnectionInfo connectionInfo = new ConnectionInfo();
  3. //取到webconfig中的连接串
  4. string sOracleCon = System.Configuration.ConfigurationManager.AppSettings["connectionString"].TrimEnd(';');
  5. //处理得到数据源,用户和密码
  6. string[] listOracleCon = new string[];
  7. string[] listOracleConTemp1 = sOracleCon.Split(';');
  8. for (int i = ; i < listOracleConTemp1.Length; i++)
  9. {
  10. string[] listOracleConTemp2 = listOracleConTemp1[i].Split('=');
  11. listOracleCon.SetValue(listOracleConTemp2[], i);
  12. }
  13. //数据库名或数据库服务
  14. connectionInfo.DatabaseName = listOracleCon[];
  15. //用户名
  16. connectionInfo.UserID = listOracleCon[];
  17. //用户密码
  18. connectionInfo.Password = listOracleCon[];
  19. //数据库地址,oracle数据库不需要设置
  20. //connectionInfo.ServerName = "localhost";
  21. //将数据库信息传递给报表 
  22. SetDBLogonForReport(connectionInfo, myReport);
  1. private void SetDBLogonForReport(ConnectionInfo connectionInfo, ReportDocument reportDocument)
  2. {
  3. Tables tables = reportDocument.Database.Tables;
  4. foreach (CrystalDecisions.CrystalReports.Engine.Table table in tables)
  5. {
  6. TableLogOnInfo tableLogonInfo = table.LogOnInfo;
  7. tableLogonInfo.ConnectionInfo = connectionInfo;
  8. table.ApplyLogOnInfo(tableLogonInfo);
  9. }
  10. }

最后,将水晶报表对象赋给页面模版

  1. //把模板对象赋给报表前端呈现控件CrystalReportViewer1
  2. CrystalReportViewer.ReportSource = myReport;

完成之后,编译,就可以在页面上看到效果了,非常的方便和快捷。

最后自己再记录一下,push模式,需要自己先通过代码连接数据库,并生成dataset,再传给水晶报表类,并赋给模版。以便后面的自学。

  1. DataSet ds = new DataSet();
  2. ReportDocument myReport = new ReportDocument();
  3. myReport.SetDataSource(ds);
  4. CrystalReportViewer.ReportSource = myReport;

关于vs2010下水晶报表的使用入门的更多相关文章

  1. [转]VS2010中水晶报表安装应用及实例

    基本分类如下:第一部分:VS2010简介VS2010是微软的提供的一套完整的开发环境,功能也是相当的大微软宣布了下一代开发工具和平台的正式名称,分别称为“Visual Studio Team Syst ...

  2. VS2010中水晶报表应用及实例

    原文:VS2010中水晶报表应用及实例 基本分类如下:第一部分:VS2010简介VS2010是微软的提供的一套完整的开发环境,功能也是相当的大微软宣布了下一代开发工具和平台的正式名称,分别称为“Vis ...

  3. Vs2010中水晶报表引用及打包

    原文:Vs2010中水晶报表引用及打包 转自:http://yunhaifeiwu.iteye.com/blog/1172283 Vs2010中水晶报表引用 在sap官网中下载支持vs 2010中的水 ...

  4. (转)VS2010结合水晶报表做条码标签打印功能

    本文转载自:http://blog.sina.com.cn/s/blog_552ca1400100y6dd.html 先来个功能效果图: 大家都知道VS2005和VS2008软件本身是包含水晶报表插件 ...

  5. VS2010与水晶报表V13的打包集成小结

    感谢孟子E章提供的技术咨询. 系统配置: Windows 7 + VS2010 , WinForm + DotNet4 + 水晶报表 这里说的打包集成,指的用VS2010的制作的安装包,在安装的时候可 ...

  6. VS2010中水晶报表插件下载安装方法

    Visual Studio 2010默认不带水晶报表,需要安装一个水晶报表插件,首先下载此插件: http://downloads.businessobjects.com/akdlm/cr4vs201 ...

  7. 【.Net】水晶报表CrystalReport粗浅入门

    VB6代码大概是这样的: crystalreport1.Connect:='dsn=xxx;uid=yyy;pwd=zzz;dsq=aaa'; crystalreport1.DiscardSavedD ...

  8. C#下水晶报表打印自定义纸张

    在VB6中,如果要自定义纸张很方便:  Rpt.PaperSize = crPaperUser  Rpt.SetUserPaperSize lZZG, lZZK 但在C#中却不行了,没有发现 SetU ...

  9. .NET环境下使用水晶报表

    .NET环境下使用水晶报表 听语音 | 浏览:3280 | 更新:2013-12-20 13:36 1 2 3 4 5 6 7 分步阅读 水晶报表(Crystal Reports)-商务智能软件,通常 ...

随机推荐

  1. JavaScript参考

    要查看英语原文,请勾选"英语"复选框.也可将鼠标指针移到文本上,在弹出窗口中显示英语原文. 翻译 英语 JavaScript 语言参考 JavaScript 是一种可嵌入网页和其他 ...

  2. web前端素材整理汇总

    最近一直搞前端开发,整理下前端用的一些常用素材,分享给大家 框架类 Vue:https://cn.vuejs.org/ iview:https://www.iviewui.com/ 插件类 Jquer ...

  3. echarts分组插件echarts.group代码分享

    前言 echarts是百度出品的一款很棒的前端图表控件,被评为"百度少有的良心产品".可以实现散点图.折线图.柱状图.地图.饼图.雷达图.K线图等等几十种常用.不常用的图表,效果酷 ...

  4. 使用hiredis实现pipeline方式访问

    1.介绍 hiredis: 一个c/c++的访问redis的api库 地址:https://github.com/redis/hiredis pipeline方式: redis中的pipeline方式 ...

  5. 通过ssh訪问NAT网络模式虚拟机里的Linux

    进入 GuestOS : #/sbin/ifconfig 查看 inet addr : 10.0.2.15 然后到 HostOS 去, 看控制面板, 看网络和共享中心的VirtualBox Host- ...

  6. SSH中的免password登录

    1:运行命令  ssh-keygen -t rsa 产生秘钥 ,位于~/.ssh目录下(假设在这期间有什么提示.一路敲击enter下去,什么都不用输入) 2:运行命令 cp  ~/.ssh/id_rs ...

  7. hdu 5635 LCP Array(BC第一题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5635 LCP Array Time Limit: 4000/2000 MS (Java/Others) ...

  8. POJ 1861:Network(最小生成树&amp;&amp;kruskal)

    Network Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 13266   Accepted: 5123   Specia ...

  9. [前端] jquery验证手机号、身份证号、中文名称

    验证: 中文姓名.手机号.身份证和地址 HTML(表单): <form action=""> <div class="form-group"& ...

  10. Material使用05 自定义主题、黑夜模式\白天模式切换

    需求: 1 不使用materil依赖内建的主题,使用自己创建的主题 2 利用自己创建的主题实现白天模式和黑夜模式 1 自定义主题 1.1 创建自定义主题文件 them.scss // 引入materi ...