ASP.NET C#学习三(水晶报表插件)

概念部分

(1).什么是报表?

用表格、图表等来展示动态的数据。报表=多言的格式+动态的数据

(2).什么是水晶报表(Crystal Reports)?

AP.NET的一系列报表应用组件。

有什么样的数据库访问模式?

1.使用ODBC的驱动程序的数据库

2.使用OLE DB驱动程序的数据库

3.AccessExcel

 

 

水晶报表的使用

(1).水晶报表下载安装(针对vs2013,针对旧版本的一搜一大把):

http://124.205.69.162/files/50470000052E741A/downloads.businessobjects.com/akdlm/cr4vs2010/CRforVS_13_0_18.exe

(2). VS2013安装了水晶报表没反应怎么办?

解决方案:http://bbs.csdn.net/topics/391017532

你试试到工具--》选择工具箱项,在.NET Framework列表里,找到Crystal Reports,前面打钩-确定

水晶报表菜单问题OK了,但使用报表组件,网页加载时又报如下错了怎么办?

报错:0x800a1391 - JavaScript运行时报错:"bobj"未定义

 


 

解决方案:http://www.cnblogs.com/muzinian/p/4721690.html

按这个步骤走完,并且每个用报表组件的.aspx引用crv.js脚本,就OK

(3).报表的访问模式:

提取模式:驱动程序自己去连接数据库,即在.aspx页面创建报表组件指定报表文件作为数据源

推入模式:代码关联指定报表数据源

(4).水晶报表组件用法:

1.先创建一个空的Web窗体;

2.然后创建一个水晶报表文件,Web窗体关联引用这个文件:

如下是水晶报表的使用过程:


 、

但是创建窗体和报表并不等于百分百能用,我用VS2013网页加载时就抛出了"bobj"未定义那个报错,因此除了gif里的.aspx配置,还要耐心的看"3"


 


3.最后,检查修改Web.config配置文件:

黄色部分都是使用完整水晶报表的配置必要项,不过大部分都会在使用报表向导创建报表的过程中自动生成,如下只有蓝色区域是我新添加的。

<?xml version="1.0"?>

<configuration>

  <configSections>

    <sectionGroup name="businessObjects">

      <sectionGroup name="crystalReports">

        <section name="rptBuildProvider" type="CrystalDecisions.Shared.RptBuildProviderHandler, CrystalDecisions.Shared, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304, Custom=null"/>

        <section name="crystalReportViewer" type="System.Configuration.NameValueSectionHandler"></section>

      </sectionGroup>

    </sectionGroup>

  </configSections>

  <connectionStrings>

    <add name="WindowsFormsApplication1.Properties.Settings.NorthwindConnectionString"

connectionString="Data Source=.;Initial Catalog=Northwind;Persist Security Info=True;User ID=sa;Password=abc123..."

providerName="System.Data.SqlClient"/>

    <add name="ConnectionString" connectionString="Provider=SQLOLEDB.1;Data Source=STEPHANIE;Persist Security Info=True;User ID=sa;Initial Catalog=MyDB" providerName="System.Data.OleDb"/>

  </connectionStrings>

  <system.web>

    <compilation debug="true" targetFramework="4.5">

      <assemblies>

        <add assembly="CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304" />

        <add assembly="CrystalDecisions.Shared, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304" />

        <add assembly="log4net, Version=1.2.10.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304" />

        <add assembly="CrystalDecisions.ReportSource, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304" />

        <add assembly="CrystalDecisions.ReportAppServer.Controllers, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304" />

        <add assembly="CrystalDecisions.ReportAppServer.DataDefModel, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304" />

        <add assembly="CrystalDecisions.CrystalReports.Engine, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304" />

        <add assembly="CrystalDecisions.ReportAppServer.ClientDoc, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304" />

        <add assembly="Microsoft.ReportViewer.WebForms, Version=11.0.0.0, Culture=neutral, PublicKeyToken=89845DCD8080CC91" />

        <add assembly="Microsoft.ReportViewer.Common, Version=11.0.0.0, Culture=neutral, PublicKeyToken=89845DCD8080CC91" />

        <add assembly="Microsoft.Build.Framework, Version=4.0.0.0, Culture=neutral, PublicKeyToken=B03F5F7F11D50A3A" />

      </assemblies>

      <buildProviders>

        <add extension=".rpt" type="CrystalDecisions.Web.Compilation.RptBuildProvider, CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304" />

        <add extension=".rdlc" type="Microsoft.Reporting.RdlBuildProvider, Microsoft.ReportViewer.WebForms, Version=11.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91" />

      </buildProviders>

    </compilation>

    <httpRuntime targetFramework="4.5"/>

    <httpHandlers>

      <add path="CrystalImageHandler.aspx" verb="GET" type="CrystalDecisions.Web.CrystalImageHandler, CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304" />

      <add path="Reserved.ReportViewerWebControl.axd" verb="*" type="Microsoft.Reporting.WebForms.HttpHandler, Microsoft.ReportViewer.WebForms, Version=11.0.0.0, Culture=neutrsyal, PublicKeyToken=89845dcd8080cc91"

        validate="false" />

    </httpHandlers>

  </system.web>

  <system.webServer>

    <handlers>

      <add name="CrystalImageHandler.aspx_GET" verb="GET" path="CrystalImageHandler.aspx" type="CrystalDecisions.Web.CrystalImageHandler, CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304" preCondition="integratedMode"/>

    </handlers>

    <validation validateIntegratedModeConfiguration="false"/>

  </system.webServer>

  <appSettings>

    <add key="aspnet:UseTaskFriendlySynchronizationContext" value="true"/>

    <add key="ValidationSettings:UnobtrusiveValidationMode" value="WebForms"/>

    <!--数据库自定义配置参数-->

    <add key="ConnectionSetting" value="Server=.;UID=sa;PWD=********;DataBase=MyDB"/>

  </appSettings>

  <businessObjects>

    <crystalReports>

      <rptBuildProvider>

        <add embedRptInResource="true"/>

      </rptBuildProvider>

      <crystalReportViewer>

        <add key="ResourceUri" value="/aspnet_client/system_web/4_0_30319/crystalreportviewers13"/>

      </crystalReportViewer>

    </crystalReports>

  </businessObjects>

</configuration>

 

4.除了使用组件直接关联指定报表文件展示数据外,还可以代码关联报表组件数据源,即推入模式访问报表:

如下新建一个Web窗体ReportPrintDemo1.aspx:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="ReportPrintDemo1.aspx.cs" Inherits="Report_ReportPrintDemo1" %>

<%@ Register assembly="CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304" namespace="CrystalDecisions.Web" tagprefix="CR" %>

<%@ Register assembly="Microsoft.ReportViewer.WebForms, Version=11.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91" namespace="Microsoft.Reporting.WebForms" tagprefix="rsweb" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">

<head runat="server">

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

    <title></title>

    <!--使用水晶报表时 添加文crv文件引用,否则报bobj空对象-->

    <script src='<%=ResolveUrl("~/crystalreportviewers13/js/crviewer/crv.js")%>'type="text/javascript"></script>

</head>

<body>

    <form id="form1" runat="server">

        <!--添加一个空的报表组件,代码中去关联铺页面-->

        <CR:CrystalReportViewer ID="CrystalReportViewer1" runat="server" AutoDataBind="true" OnInit="CrystalReportViewer1_Init" />

    </form>

</body>

</html>

其中黄色部分加粗并圈黄的是新加的部分。类型为CrystalReportViewer的组件在工具箱拖过来的如图:

 

 

 

然后去页面ReportPrintDemo1.aspx的对应逻辑类ReportPrintDemo1.aspx.cs编写报表数据源的绑定,其中以下紫色圈起来的部分比较重要。实现了加载我们刚刚建好的报表文件并将查询结果填到报表文件。最后将界面报表组件和报表数据关联起来。完整代码如下:

using System;

using System.Configuration;

using System.Data.SqlClient;

using CrystalDecisions.CrystalReports.Engine;//ReportDocument的命名空间

//备注:通过代码的方式关联报表数据源

public partial class Report_ReportPrintDemo1 : System.Web.UI.Page

{

    protected void Page_Load(object sender, EventArgs e)

    {

        //使用CrystalReportDemo.rpt报表文件将表查询结果铺到CrystalReportViewer1空间上

        string connstr = ConfigurationManager.AppSettings["ConnectionSetting"].ToString();

        SqlConnection conn = new SqlConnection(connstr);

        conn.Open();

        try

        {

            SqlDataAdapter sda = new SqlDataAdapter("select * from table_2 order by student_id", conn);

            DataSet ds = new DataSet();

            sda.Fill(ds, "table_2");

            ReportDocument rd = new ReportDocument();

            //相对路径加载

            rd.Load(Server.MapPath(@"Report\PrintDemo1\CrystalReportDemo1.rpt"));

            //绝对路径加载                           //rd.Load(@"E:\Documents\Code\ASPDNet\WebStudy2\Report\PrintDemo1\CrystalReportDemo1.rpt");

            rd.SetDataSource(ds);

            this.CrystalReportViewer1.ReportSource = rd;

        }

        catch (System.Exception ex)

        {

            Response.Write(ex.Message);

        }

        finally

        {

            conn.Close();

        }

    }

}

 

水晶报表的其他知识

报表文件有很多配置选项:指定检索条件、分组、排序等等。

 

抑制显示

formula 抑制显示字段值,如下以Basix语法为例 指定默认不显示,满足条件后formulafalse时才显示

formula = true

if {table_2.sex} = "gril" and {table_2.age} > 5 then

formula = false

end if

 

图标插件

水晶报表中包含一些基础的统图表,可以在报表文件插入图表选择使用

 

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值