水晶报表技术(4)——C#.Net的WinForm中使用水晶报表

简介:
1)在使用自带的水晶报表时,请注册,否则只能使用30
2)
使用CrystalReportViewer进行预览
CrystalReportViewer
控件允许在应用程序中查看 Crystal ReportReportSource 属性用于设置要查看哪个报表。该属性设置之后,报表显示在查看器中。报表源可以是ReportDocument、报表文件的路径,也可以是强类型报表。
(1)
打开工具箱,并将一个 CrystalReportViewer 拖到窗体上,我们命名为rptVew  
(2)
通过拖放操作将 Windows 窗体查看器调整到希望的大小并将其移动到所需位置。
 
(3)
当运行应用程序时,报表将显示在查看器中。

3)
创建新报表
(1)
指向添加,单击添加新项  
(2)
添加新项对话框中,从模板区域选择 Crystal Report,将报表命名为rptClient,单击打开
 
(3)
 Crystal Report 库中,选择下列选项之一:
 
A.
使用报表专家 -> 指导您完成报表的创建过程,并将您的选择添加到 Crystal Report Designer
 
B.
作为空白报表 -> 打开 Crystal Report Designer
 
C.
来自于现有的报表 -> 创建新报表,它与指定的另一报表设计相同。
 
注意 Crystal Report 库包含许多专家,可以指导您完成数个特定类型报表的创建工作。您可能希望使用专家来创建最初的报表,以确定哪种报表构造方法适合您的需要。

(4)
单击确定按钮。  
如果选择使用报表专家,便会出现报表专家对话框,并带有数据资源管理器。为每个文件夹选择所需数据,完成报表专家选项卡界面上的操作,然后单击完成来访问 Crystal Report Designer 和您的报表。

(5)
是否需要动态设置数据源?
Crystal Reports 
通过数据库驱动程序与数据库连接。每个驱动程序都被编写为可处理特定数据库类型或数据库访问技术。拉和推模型,为了向开发人员提供最灵活的数据访问方法,Crystal Reports 数据库驱动程序被设计为可同时提供数据访问的拉模型和推模型。  
拉模型pull:在拉模型中,驱动程序将连接到数据库并根据需要将数据进来。使用这种模型时,与数据库的连接和为了获取数据而执行的 SQL 命令都同时由 Crystal Reports 本身处理,不需要开发人员编写代码。如果在运行时无须编写任何特殊代码,则使用拉模型。

推模型push:相反,推模型需要开发人员编写代码以连接到数据库,执行 SQL 命令以创建与报表中的字段匹配的记录集或数据集,并且将该对象传递给报表。该方法使您可以将连接共享置入应用程序中,并在 Crystal Reports 收到数据之前先将数据筛选出来。  
4)
 ADO.NET 数据集制作报表

从数据库创建数据集对象
(1)
在项目中新建一个架构文件:  
在解决方案资源管理器中,右击项目名,指向添加,然后单击添加新项。在添加新项对话框的类别区域,展开文件夹,然后选择数据 模板区域选择数据集 接受默认名称 Dataset1.xsd 这就创建了一个新的架构文件 (Dataset1.xsd),以后将用它来生成强类型数据集。该架构文件将显示在 ADO.NET 数据集设计器中。
 
(2)
指定数据库位置:
 
在服务器资源管理器中,右击数据连接并选择添加连接。在数据链接属性对话框中,单击提供程序选项卡,然后选择一个提供程序(例如 Microsoft OLE DB Provider for SQL Server)。 单击连接选项卡,然后指定您的数据库所在位置。在所需位置输入服务器和登录信息。 单击确定按钮。 此时,您的数据库及其表和字段就出现在服务器资源管理器的数据连接节点下面。
 
(3)
在解决方案资源管理器中,双击 Dataset1.xsd (如果它尚不是活动视图)。 Dataset1.xsd 现在应显示在数据集选项卡中。
 
(4)
若要为数据集建立架构,请将需要的表从服务器资源管理器中拖动到 Dataset1.xsd 数据集选项卡上。
 
(5)
单击保存 Dataset1.xsd”来保存“Dataset1.xsd”文件。
 
(6)
生成菜单上,单击生成为项目生成数据集对象。
 
ADO.NET 
数据集对象提供数据的描述,从它可以向 Crystal report 添加表。使用 Crystal Report Designer 中的数据库专家 ADO.NET 数据集对象添加表。 请在使用报表专家创建新报表时调用数据库专家。或者,要从一个已经使用 ADO.NET 建立好的报表中访问数据库专家,请在 Report Designer 中右击,指向数据库,然后单击添加/删除数据库。将报表连接到 ADO.NET数据集对象
 
(1)
数据库专家中,展开项目数据文件夹。
 
(2)
展开“ADO.NET 数据集文件夹。
 
(3)
选择所需数据集对象。
 
例如,如果当时使用的是从项目“WindowsApplication1”的架构文件“Dataset1.xsd”中生成的数据集对象,则应该选择“WindowsApplication1.Dataset1” 选择要向报表中添加的表,和使用其他数据源一样。
 

5)
动态改变数据源的代码

DataSet dsdataSet = new DataSet();
rptClient() oRpt = new rptClient(); //
已建立的报表 rptClient
OleDbDataAdapter da=new OleDbDataAdapter("select * from TableName",conn);
da.Fill(dsdataSet,"TableName");
//
使用报表引擎对象模型将填充的数据集,传递给报表

oRpt.SetDataSource(dsdataSet.Tables(0));
//
将带有数据的报表对象绑定到 Windows 窗体查看器,rptVewCrystalReportViewer控件)
rptVew.ReportSource = oRpt;
注意 FillDataSet 方法可连接到指定的数据库,提取数据,然后断开数据库连接。如果您希望将数据库中的多个表添加到报表中,请使用 SQL JOIN 语句将这些表联接在一起;然后在 FillDataSet 方法中指定一个结果表。

6)
创建主从报表
在报表中,有许多报表是主从表结构,比如订单与订单商品明细,订单是一个表中的一条记录,而分录是另一个表中的多条记录,两个表通过一个字段关联起来,这种报表可利用其分组功能实现。
(1)
新建一个工程
(2)
FORM1中添加一个CrystalReportViewer控件
(3)
在服务噐资源管理器中连接到SQL SERVER 2000上的Northwind数据库
(4)
添加一个数据集Dataset1,将服务器资源管理器中的Orders Order Details加入到数据集中。
(5)
添加一个水晶报表,使用报表专家,在项目数据中选择“ADO.NET数据集,插入表Orders Order Details链接中是关联字段的链接,在字段中选择要显示的主表和明细表的字段,组中选择分组依据为OrdersOrdersID字段,总计,图表,选择(可进行筛选),样式(可设置报表标题),可自行设置。设置完后,点击完成。
(6)
在报表设计器中调整需要显示的字段的位置、宽度等。
(7)
在窗口中添加代码。
public PrintForm()
{
InitializeComponent();

OleDbConnection conn=new OleDbConnection("data source=PMSERVER;initial catalog=Northwind;user id=sa;password=sa");
Dataset1() ds = new Dataset1();

OleDbDataAdapter da1=new OleDbDataAdapter("select * from orders",conn);
da1.Fill(ds,"orders");

OleDbDataAdapter da2=new OleDbDataAdapter("select * from [Order Details]",conn);
da2.Fill(ds,"Order Details");

CrystalReport1 oCR=new CrystalReport1();
oCR.SetDataSource(ds);
this.crystalReportViewer1.ReportSource = oCR;
}
(8)
运行程序

3
、水晶报表登陆失败
using CrystalDecisions.Shared;
//
声明所需变量。
TableLogOnInfo logOnInfo = new TableLogOnInfo();
//
对报表中的每个表依次循环。
for (int i=0;i < Report.Database.Tables.Count-1;i++)
{
//
设置当前表的连接信息。
logOnInfo.ConnectionInfo.ServerName = serverNameTxt.Text;
logOnInfo.ConnectionInfo.DatabaseName = dbNameTxt.Text;
logOnInfo.ConnectionInfo.UserID = userNameTxt.Text;
logOnInfo.ConnectionInfo.Password = passwordTxt.Text;
Report.Database.Tables [i].ApplyLogOnInfo (logOnInfo);
}
注意 受密码保护的 Microsoft Access  Paradox  PC 数据库也使用该方法,但 LogOnInfo.ServerName为数据文件的路径, LogOnInfo.DatabaseName 要保留为空。TableLogOnInfo 是属于CrystalDecisions.Shared 命名空间的成员。要添加引用:using CrystalDecisions.Shared;

4
、水晶报表应用程序的发布
1)
安装部署
安装部署时,把水晶报表的msm打进去,注册到服务器,要部署使用 Crystal Reports for Visual Studio .NET 2003 的程序,首先,找到以下7个文件(你可以 'C:\Program Files\Common Files\Merge Modules' 文件夹下找到)
Crystal_Database_Access2003.msm 
Crystal_Database_Access2003_chs.msm 
Crystal_Managed2003.msm
Crystal_Managed2003_chs.msm
Crystal_regwiz2003.msm 
VC_User_CRT71_RTL_X86_---.msm 
VC_User_STL71_RTL_X86_---.msm
接着,在解决方案资源管理器中,右击安装项目,指向添加,然后单击合并模块。在添加模块对话框中,选择上面的7个要添加到安装项目的合并模块,然后单击打开
还有,打开解决方案-->右键点击 Crystal_regwiz2003.msm 的属性,在“MergeMouduleProperties”里的“License Key”填入:AAP5GKS0000GDE100DS(这个是你生成Crystal Report是用到的注册号的密码!)




本文转自 qianshao 51CTO博客,原文链接:http://blog.51cto.com/qianshao/203443,如需转载请自行联系原作者

目录
相关文章
|
11天前
|
数据可视化 网络协议 C#
C#/.NET/.NET Core优秀项目和框架2024年3月简报
公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架(每周至少会推荐两个优秀的项目和框架当然节假日除外),公众号推文中有项目和框架的介绍、功能特点、使用方式以及部分功能截图等(打不开或者打开GitHub很慢的同学可以优先查看公众号推文,文末一定会附带项目和框架源码地址)。注意:排名不分先后,都是十分优秀的开源项目和框架,每周定期更新分享(欢迎关注公众号:追逐时光者,第一时间获取每周精选分享资讯🔔)。
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
62 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
1月前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
58 1
|
1月前
|
并行计算 安全 Java
C# .NET面试系列四:多线程
<h2>多线程 #### 1. 根据线程安全的相关知识,分析以下代码,当调用 test 方法时 i > 10 时是否会引起死锁? 并简要说明理由。 ```c# public void test(int i) { lock(this) { if (i > 10) { i--; test(i); } } } ``` 在给定的代码中,不会发生死锁。死锁通常是由于两个或多个线程互相等待对方释放锁而无法继续执行的情况。在这个代码中,只有一个线程持有锁,且没有其他线程参与,因此不
102 3
|
2月前
|
SQL 数据库连接 应用服务中间件
C#WinForm基础编程(三)
C#WinForm基础编程
71 0
|
4天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
9天前
|
数据采集 C# 数据安全/隐私保护
掌握 C# 爬虫技术:使用 HttpClient 获取今日头条内容
本文介绍了如何使用C#的HttpClient与爬虫代理IP技术抓取今日头条内容,以实现高效的数据采集。通过结合亿牛云爬虫代理,可以绕过IP限制,增强匿名性。文中提供了一个代码示例,展示如何设置代理服务器信息、请求头,并用正则表达式提取热点新闻标题。利用多线程技术,能提升爬虫采集效率,为市场分析等应用提供支持。
掌握 C# 爬虫技术:使用 HttpClient 获取今日头条内容
|
1月前
|
开发框架 人工智能 .NET
C#/.NET/.NET Core拾遗补漏合集(持续更新)
C#/.NET/.NET Core拾遗补漏合集(持续更新)
|
1月前
|
C# 开发者
35.c#:winform窗口
35.c#:winform窗口
10 1
|
1月前
|
SQL 存储 关系型数据库
C# .NET面试系列十:数据库概念知识
#### 1. 为什么要一定要设置主键? 设置主键是数据库设计中的一个重要概念,有几个主要原因: 1、唯一性 ```c# 主键必须保证表中的每一行都有唯一的标识。这样可以避免数据冗余和不一致性。如果没有主键或者主键不唯一,就可能出现数据混乱或错误。 ``` 2、查询性能 ```c# 数据库系统通常会使用主键来加速数据检索。主键通常会被索引,这样可以更快速地找到特定行的数据,提高查询效率。 ``` 3、关联性 ```c# 主键常常用于建立表与表之间的关系。在关系数据库中,一个表的主键通常与其他表中的外键建立关联,这种关系对于数据的一致性和完整性非常重要。 ``` 4、数据完
131 1
C# .NET面试系列十:数据库概念知识