Crystal Reports(水晶报表)安装及拉(PULL)模式/推(PUSH)模式的使用

简介&安装

2017915

1.1简介

Crystal Reports(水晶报表)是一款商务智能(BI)软件,主要用于设计及产生报表。

水晶报表是业内最专业、功能最强的报表系统,它除了强大的报表功能外。

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

  • 页面可以进行报表的打印和导出功能。
  • 存在问题:无法动态更新数据

 

1.2 安装步骤

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

插件下载地址:

http://www.aspsnippets.com/Articles/Download-Crystal-Reports-for-Visual-Studio-2013.aspx

插件安装成功后打开VS2013,会发现工具箱里多了以下这些,

那么说明VS2013已经安装了水晶报表的插件,可以创建水晶报表。

 

2.1 拉(PULL)模式

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

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

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

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窗体,在设计页面放置水晶报表控件。然后在aspx.cs文件内添加如下代码即可实现水晶报表拉模式。

using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using CrystalDecisions.CrystalReports.Engine;
using CrystalDecisions.Shared;

public partial class CrystralReport : 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("Report/CrystalReport.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;
        }
    }
}

 

Crystal Reports 9.2 中文版(水晶报表) 下载,,软件版本:9.2.0.448不过现已出了Crystal Reports Professional v9.2.2.634 (c) Crystal Decisions,有足够的空间就提供.这是一个很不错的报表控件,我相信很多朋友都听说过吧!Crystal Reports 用于处理数据库,帮助用户分析和解释重要信息。使用 Crystal Reports 可以方便地创建简单报表,同时它也提供了创建复杂或专用的报表所需的整套工具。 创建所能想象的任何报表 Crystal Reports几乎可以从任何数据源生成您需要的报表。内置报表专家在您生成报表和完成一般的报表任务过程中,会一步一步地指导您进行操作。报表专家通过公式、交叉表、子报表和设置条件格式帮助表现数据的实际意义,揭示可能被隐藏掉的重要关系。如果文字和数字确实不够充分,则用地理地图和图形进行形象的信息交流。 将报表扩展到 Web Crystal Reports 的灵活性并未停留在创建报表这一功能上 ?您可以用各种各样的格式发布报表,包括用 Microsoft 的 Word 和 Excel 发布、通过电子邮件甚至 Web 发布。高级的 Web 报表功能允许工作组中的其他成员在他们自己的 Web 浏览器中查看或更新共享报表。 将报表并入应用程序通过将 Crystal Reports 的报表处理功能整合到自己的数据库应用程序中,应用程序和 Web 开发人员可以节省开发时间并满足用户的需求。Crystal Reports 支持大多数流行的开发语言,可以方便地在任何应用程序中添加报表。 不论您是 IT 行业的站点管理员,还是营销广经理,也无论您是金融业的数据库管理员还是 CEO,Crystal Reports 都堪称是一个功能强大的工具,它可以帮助每一个人分析、解释重要信息。感谢 revenant 上传!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值