关于vs2010下水晶报表的使用入门
关于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模式。
首先,初始化水晶报表类并装载好需要的模版。
//找到水晶报表模版,我的水晶报表是放在web系统根目录下的WebReport文件夹中的,
string MasterplateName = "test.rpt";
string reportPath = Server.MapPath(Request.ApplicationPath + "/WebReport/" + MasterplateName);
ReportDocument myReport = new ReportDocument();
myReport.Load(reportPath);
接下来,需要重新为模版的数据库连接指定连接串防止,水晶报表连接不到数据库
//定义水晶报表的数据库连接信息
ConnectionInfo connectionInfo = new ConnectionInfo();
//取到webconfig中的连接串
string sOracleCon = System.Configuration.ConfigurationManager.AppSettings["connectionString"].TrimEnd(';');
//处理得到数据源,用户和密码
string[] listOracleCon = new string[];
string[] listOracleConTemp1 = sOracleCon.Split(';');
for (int i = ; i < listOracleConTemp1.Length; i++)
{
string[] listOracleConTemp2 = listOracleConTemp1[i].Split('=');
listOracleCon.SetValue(listOracleConTemp2[], i);
}
//数据库名或数据库服务
connectionInfo.DatabaseName = listOracleCon[];
//用户名
connectionInfo.UserID = listOracleCon[];
//用户密码
connectionInfo.Password = listOracleCon[];
//数据库地址,oracle数据库不需要设置
//connectionInfo.ServerName = "localhost";
//将数据库信息传递给报表
SetDBLogonForReport(connectionInfo, myReport);
private void SetDBLogonForReport(ConnectionInfo connectionInfo, ReportDocument reportDocument)
{
Tables tables = reportDocument.Database.Tables;
foreach (CrystalDecisions.CrystalReports.Engine.Table table in tables)
{
TableLogOnInfo tableLogonInfo = table.LogOnInfo;
tableLogonInfo.ConnectionInfo = connectionInfo;
table.ApplyLogOnInfo(tableLogonInfo);
}
}
最后,将水晶报表对象赋给页面模版
//把模板对象赋给报表前端呈现控件CrystalReportViewer1
CrystalReportViewer.ReportSource = myReport;
完成之后,编译,就可以在页面上看到效果了,非常的方便和快捷。

最后自己再记录一下,push模式,需要自己先通过代码连接数据库,并生成dataset,再传给水晶报表类,并赋给模版。以便后面的自学。
DataSet ds = new DataSet();
ReportDocument myReport = new ReportDocument();
myReport.SetDataSource(ds);
CrystalReportViewer.ReportSource = myReport;
关于vs2010下水晶报表的使用入门的更多相关文章
- [转]VS2010中水晶报表安装应用及实例
基本分类如下:第一部分:VS2010简介VS2010是微软的提供的一套完整的开发环境,功能也是相当的大微软宣布了下一代开发工具和平台的正式名称,分别称为“Visual Studio Team Syst ...
- VS2010中水晶报表应用及实例
原文:VS2010中水晶报表应用及实例 基本分类如下:第一部分:VS2010简介VS2010是微软的提供的一套完整的开发环境,功能也是相当的大微软宣布了下一代开发工具和平台的正式名称,分别称为“Vis ...
- Vs2010中水晶报表引用及打包
原文:Vs2010中水晶报表引用及打包 转自:http://yunhaifeiwu.iteye.com/blog/1172283 Vs2010中水晶报表引用 在sap官网中下载支持vs 2010中的水 ...
- (转)VS2010结合水晶报表做条码标签打印功能
本文转载自:http://blog.sina.com.cn/s/blog_552ca1400100y6dd.html 先来个功能效果图: 大家都知道VS2005和VS2008软件本身是包含水晶报表插件 ...
- VS2010与水晶报表V13的打包集成小结
感谢孟子E章提供的技术咨询. 系统配置: Windows 7 + VS2010 , WinForm + DotNet4 + 水晶报表 这里说的打包集成,指的用VS2010的制作的安装包,在安装的时候可 ...
- VS2010中水晶报表插件下载安装方法
Visual Studio 2010默认不带水晶报表,需要安装一个水晶报表插件,首先下载此插件: http://downloads.businessobjects.com/akdlm/cr4vs201 ...
- 【.Net】水晶报表CrystalReport粗浅入门
VB6代码大概是这样的: crystalreport1.Connect:='dsn=xxx;uid=yyy;pwd=zzz;dsq=aaa'; crystalreport1.DiscardSavedD ...
- C#下水晶报表打印自定义纸张
在VB6中,如果要自定义纸张很方便: Rpt.PaperSize = crPaperUser Rpt.SetUserPaperSize lZZG, lZZK 但在C#中却不行了,没有发现 SetU ...
- .NET环境下使用水晶报表
.NET环境下使用水晶报表 听语音 | 浏览:3280 | 更新:2013-12-20 13:36 1 2 3 4 5 6 7 分步阅读 水晶报表(Crystal Reports)-商务智能软件,通常 ...
随机推荐
- Linux服务器制定mysql数据库备份的计划任务
首先,创建一个shell脚本: Shell #!/bin/bash mysql_pwd="1234567890" mysql_dump="/usr/local/mysql ...
- Android注解方式实现表单校验
在开发中总会遇到输入框的输入规则限制 比如 电话输入框电话号码的校验,密码规则的校验等 ,我们通常做法是提交操作时对每个输入框的输入内容进行校验,很多的if else ,代码看起来很乱,其实我们可以用 ...
- 对datatable进行简单的操作
筛选出datatable中c_level=1的数据 dataRow[] rows = dt.Select("c_level=0"); 克隆表dt的结构到表dt,并将dt的数据复制到 ...
- PHP运算符优先级 运算符分类
运算符 运算符是可以通过给出的一或多个值(用编程行话来说,表达式)来产生另一个值(因而整个结构成为一个表达式)的东西. 运算符可按照其能接受几个值来分组.一元运算符只能接受一个值,例如 !(逻辑取反运 ...
- 深入理解Java内存模型——volatile
volatile的特性 当我们声明共享变量为volatile后,对这个变量的读/写将会非常特别. 理解volatile特性的一个好方法是:把对volatile变量的单个读/写,看成是使用同一个监视器锁 ...
- iOS_应用程序的生命周期
每个iPhone程序都包括唯一一个UIApplication对象,它管理整个程序的生命周期,从载入第一个显示界面開始,而且监听系统事件.程序事件调度整个程序的运行. int main(int argc ...
- C++、Objective-C 混合编程
在XCODE中想使用C++代码,你须要把文件的扩展名从.m改成.mm.这样才会启动g++编译器. 我们来看个測试代码: [java] view plaincopy class TestC { priv ...
- Android中相机和相冊使用分析
Android中相机和相冊使用分析 欢迎转载,但请尊重原创(文章来自不易,转载请标明转载出处,谢谢) 在手机应用程序中,使用自带的相机拍照以及相冊选择喜欢的图片是最常见只是的用户需求,那么怎么合理使用 ...
- swift手记-4
// // ViewController.swift // learn4 // // Created by myhaspl on 16/1/23. // Copyright (c) 2016年 myh ...
- 5. Effective Java 第三版——使用依赖注入取代硬连接资源
Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...