一、水晶报表简介

Crystal Reports(水晶报表)是一款商务智能(BI)软件,主要用于设计及产生报表。水晶报表是业内最专业、功能最强的报表系统,它除了强大的报表功能外。最大的优势是实现了与绝大多数流行开发工具的集成和接口。在VS.Net平台做过报表开发的程序员,一定都对水晶报表强大、高效、集成等特性留下了深刻印象。 除了开发新程序外,在工作中我们常需要接触到很多较早的软件系统报表功能升级的需求,如果能结合水晶报表这一强大的工具,往往能事半功倍。

二、水晶报表的实现模式

在讲解水晶报表实现模式之前,首先讲解一下我的电脑使用配置环境:

  Visual Studio 2013与SQL Server 2012

因为VS2013没有自带创建水晶报表的功能,所以需要到网上下载并安装一个插件,才能使用VS2013创建水晶报表。

插件下载地址:http://www.aspsnippets.com/Articles/Download-Crystal-Reports-for-Visual-Studio-2013.aspx

插件安装成功后打开VS2013,会发现工具箱里多了这些东西,那么说明你的VS2013已经安装了水晶报表的插件,现在可以通过VS2013创建水晶报表了。

2.1、拉(PULL)模式

概念介绍:拉模式是由水晶模板(引擎)直接连接数据库(源),从数据库(源)里拉取数据。

2.1.1、不敲一句代码创建水晶报表拉模式

1、首先在创建水晶报表拉模式之前我们需要准备数据库数据:

use master
go
create database Demo
go
use Demo
go
create table Dept
(
ID int primary key identity(1,1),
DeptID nvarchar(10),
DeptName nvarchar(10)
)
go
create table UserInfo
(
ID int primary key identity(1,1),
UserName nvarchar(10),
Salary decimal(10,2),
Gender bit,
DeptID int foreign key references Dept(ID)
)
go
insert into Dept values('HR','人事部')
insert into Dept values('DT','开发部')
go
insert into UserInfo values('程序猿1',2500,1,2)
insert into UserInfo values('程序猿2',3500,0,2)
insert into UserInfo values('程序猿3',5500,0,1)
insert into UserInfo values('程序猿4',6500,1,1)
insert into UserInfo values('程序猿5',10500,1,2)
go

2、然后,打开VS2013创建一个空网站项目。

3、接着在该项目下右键添加一个Reports文件夹,用来管理水晶报表。

4、接着 在文件夹下右键选择添加"新建项目",找到"CrystalReports",输入报表名称。

5、点击添加按钮后,会弹出默认的水晶报表向导对话框,我们按向导默认选项。

6、确定后,打开“标准报表创建向导”界面。

7、连接数据库成功后,会在简历连接那里出现你的连接信息,然后选择你要显示的表。

8、这里选择你要显示的表字段。

9、点击下一步后后面弹出的选项可以不用选择,因为暂时还用不着,所以后面一直点击下一步到完成会出现以下界面。

10、看到上面这个界面,说明你已经创建了一个水晶报表模板,因为是直接连接数据库的,所以我们可以能立即看到实际的效果,点击最下面的主报表预览,即可显示数据库的表数据。

至此,我们没有敲过任何代码,拉模式报表创建完成。

2.1.2、在Web中使用水晶报表拉模式

在之前创建的项目中,添加一个Web窗体,命名为CrystalReport_Pull.aspx。

然后打开设计页面,找到工具箱中的报表设计,双击或单击拖入到Web窗体中,如下图所示。

方式一:不敲代码通过设计器绑定数据源,显示数据。

点击确定后,你会看到Web窗体如下界面。

点击源,可以看到如下界面,设计器会自动生成以下代码。

最后我们运行VS2013在浏览器中查看效果,发现什么都没有显示,然后打开浏览器调试工具发现,报了以下错误。

解决此问题参考网站:http://stackoverflow.com/questions/31721443/crystal-report-with-visual-studio-2013-aspnet-client-system-web-4-6-81

此问题解决办法如下:找到C:\inetpub\wwwroot此目录下的文件夹,然后拷贝到你的项目的根目录下。

重新编译,再运行浏览查看,如下图,可以看到数据可以正常显示。

方式二:通过后台编写代码,连接数据库绑定数据源,显示数据。

重新添加一个Web窗体,创建步骤与上面一致。然后右键点击查看源代码,添加如下代码即可实现水晶报表拉模式。

 using CrystalDecisions.CrystalReports.Engine;
using CrystalDecisions.Shared;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; namespace ch02
{
public partial class CrystalReport_Pull : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
ConfigureCrystalReports();
} private ReportDocument myReport;
private void ConfigureCrystalReports()
{
//定义ReportDocument对象,装载Crystalreport1.rpt
myReport = new ReportDocument();
string reportPath = Server.MapPath("Reports/CrystalReport1.rpt");
myReport.Load(reportPath);
//把模板对象赋给报表前端呈现控件CrystalReportViewerl
CrystalReportViewer1.ReportSource = myReport;
}
}
}

实现效果同上

2.2、推(PUSH)模式

概念介绍:由应用程序从数据库(源)获取数据,然后把数据推送给水晶报表引擎。水晶报表本身不与数据库进行交互。

1、要实现水晶报表推模式,首先我们需要在 网站项目中添加一个数据集。

2、然后你有两种方式 创建数据表,这里我们选择方式二创建。

3、把要显示的表拖入右边。

4、接下来要设计一个水晶报表模板。在Reports文件夹上右键添加新建项,步骤与上面推模式步骤一致,这里就不再详细解说。

5、最后我们开始编写页面CrystalReport_Push.aspx后台代码。

首先引入如下命名空间:

using CrystalDecisions.CrystalReports.Engine;
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; namespace ch02
{
public partial class CrystalReport_Push : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
LoadCrystalReports();
} //加载水晶报表
private void LoadCrystalReports()
{
DataSet ds = new DataSet();
string connStr = @"server=PC-201511211346\MSSQLSERVER2;database=Demo;uid=sa;pwd=123456";
using (SqlConnection conn = new SqlConnection(connStr))
{
conn.Open();
string SQL = "select * from UserInfo";
SqlDataAdapter sda = new SqlDataAdapter(SQL, conn);
sda.Fill(ds, "UserInfo");
}
ReportDocument rd = new ReportDocument();
//获取报表路径
string reportPath = Server.MapPath("Reports/CrystalReport2.rpt");
rd.Load(reportPath);
//绑定数据集,注意一个表用一个数据集。
rd.SetDataSource(ds);
CrystalReportViewer1.ReportSource = rd;
}
}
}

最后运行查看效果:

总结:此文章是对ASP.NET 水晶报表(Crystal Reports)的简单使用做了一个学习总结,目的是为了帮助想要学习水晶报表的初学者做了一个入门指导,让初学者少走一些弯路。

报表学习总结(一)——ASP.NET 水晶报表(Crystal Reports)的简单使用的更多相关文章

  1. ASP.NET Dev ASPxGridView控件使用 ASP.NET水晶报表打印

    1.ASPxGridView控件使用 2.ASP.NET水晶报表客户端打印 3.javascript打印 4.ASPxGridView根据Textbox查询 5. ASPxGridView 列宽 1. ...

  2. asp.net实现通用水晶报表

    此片博文是在你有一定水晶报表基础的前提下参阅的:如果对于水晶报表的基础知识比较薄弱建议先去了解下水晶报表: 因为项目需要,研究了下水晶报表.说实在,这个组件很强大,但是用起来也很麻烦.刚开始使用遇到了 ...

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

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

  4. (转)VS.NET2010水晶报表安装部署[VS2010]

    本文转载自:http://www.cnblogs.com/xiaofengfeng/p/3325793.html 欢迎C#高手加盟QQ群:9340166 水晶报表VS2010版IDE安装标准版SAP ...

  5. VS.NET2010水晶报表安装部署

    水晶报表VS2010版IDE安装标准版SAP Crystal Reports, version for Visual Studio 2010 - Standard: 下载地址: http://down ...

  6. VS.NET2010水晶报表安装部署[VS2010]

    水晶报表VS2010版IDE安装标准版SAP Crystal Reports, version for Visual Studio 2010 - Standard: 下载地址: http://down ...

  7. 水晶报表 VS2010 应用

    VS.NET2010水晶报表安装部署[VS2010]   欢迎C#高手加盟QQ群:9340166 水晶报表VS2010版IDE安装标准版SAP Crystal Reports, version for ...

  8. 关于vs2010下水晶报表的使用入门

    关于vs2010下使用水晶报表了解情况记录如下: 1.首先vs2010不再自带水晶报表控件了,需要下载安装vs2010配套的水晶报表控件:CRforVS_13_0.这个控件安装很简单,基本上都选择默认 ...

  9. VS2015安装水晶报表

    最近在做一个打印功能,本来是不想用水晶报表的.想直接用微软原生的报表rdlc完成,但是整了一个上午老是打印乱码,且网上找资料找也找不出. 无奈放弃,然后就想到用水晶报表了,以前用过水晶报表,不过一直都 ...

随机推荐

  1. windows下 nginx php 环境搭建

    windows下配置nginx+php环境 刚看到nginx这个词,我很好奇它的读法(engine x),我的直译是“引擎x”,一般引“擎代”表了性能,而“x”大多出现是表示“xtras(额外的效果) ...

  2. 为CKEditor开发插入代码的插件 已提供下载

    http://www.cnblogs.com/moozi/archive/2010/01/06/1640034.html

  3. How to setup Eclipse with WinAVR and the Eclipse plugin AVR-eclipse

    源:How to setup Eclipse with WinAVR and the Eclipse plugin AVR-eclipse Arduino development with Eclip ...

  4. STM8S awu及看门狗IWDG WWDG应用(转)

    源:STM8S awu及看门狗IWDG WWDG应用 AWU的应用(用库函数完成的) //切记要开启中断 且在中断函数中 AWU_GetFlagStatus(); 来清除中断 void AWU_SET ...

  5. winscp 秘钥登录

    如题 如果不想用密码登录,可以选择用秘钥文件登录winscp 原理和linux分发ssh公钥是一个道理 1:在被管理的机器上分发公钥 ,出现 authorized_keys才可以 完成服务端配置 2: ...

  6. STM32标准IIC驱动

    IIC(Inter-Integrated Circuit)总线是一种由 PHILIPS 公司开发的两线式串行总线,用于连接 微控制器及其外围设备.也是目前很流行的通讯总线,使用IIC总线做产品能够很大 ...

  7. jQuery EasyUI学习资源汇总

    jQuery EasyUI学习资源汇总 EasyUi – 1.入门 EasyUi – 2.布局Layout + 3.登录界面 EasyUi – 4.datwagrid 学习Jquery EasyUI的 ...

  8. .net面试题【持续更新.....】

    1.C#中readonly和const的区别? 2.C#中的排序继承自哪个接口?Icompare 3.阐述单点登录的实现原理? 4.C#中property和Attribute的区别? 5.Datase ...

  9. 如何开发一个微信小程序

    一.概述     特点:对商家来说,小程序的开发成本低(有丰富的组件.api等).运营成本低(有数据日志等).稳定.互动流畅,便于分享.传播(基本微信平台的大量用户).对用户来说,扫码即可获取服务,随 ...

  10. sql server mdf碎片级数据库修复,数据库碎片级提取

    sql server mdf碎片级数据库修复,数据库碎片级提取   大家都知道MDF数据库文件一般都比较大,在磁盘中往往被存放到不连续的逻辑簇中,久而久之就形成了文件碎片,当文件被误删除或者格式化后, ...