用表格、图表等来展示动态的数据。报表=多言的格式+动态的数据
(1).水晶报表下载安装(针对vs2013,针对旧版本的一搜一大把):
http://124.205.69.162/files/50470000052E741A/downloads.businessobjects.com/akdlm/cr4vs2010/CRforVS_13_0_18.exe
解决方案: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了
提取模式:驱动程序自己去连接数据库,即在.aspx页面创建报表组件指定报表文件作为数据源
但是创建窗体和报表并不等于百分百能用,我用VS2013网页加载时就抛出了"bobj"未定义那个报错,因此除了gif里的.aspx配置,还要耐心的看"3"。
黄色部分都是使用完整水晶报表的配置必要项,不过大部分都会在使用报表向导创建报表的过程中自动生成,如下只有蓝色区域是我新添加的。
<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>
<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"/>
<compilation debug="true" targetFramework="4.5">
<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" />
<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" />
<httpRuntime targetFramework="4.5"/>
<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"
<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"/>
<validation validateIntegratedModeConfiguration="false"/>
<add key="aspnet:UseTaskFriendlySynchronizationContext" value="true"/>
<add key="ValidationSettings:UnobtrusiveValidationMode" value="WebForms"/>
<add key="ConnectionSetting" value="Server=.;UID=sa;PWD=********;DataBase=MyDB"/>
<add embedRptInResource="true"/>
<add key="ResourceUri" value="/aspnet_client/system_web/4_0_30319/crystalreportviewers13"/>
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" %>
<html xmlns="http://www.w3.org/1999/xhtml">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<!--使用水晶报表时 添加文crv文件引用,否则报bobj空对象-->
<script src='<%=ResolveUrl("~/crystalreportviewers13/js/crviewer/crv.js")%>'type="text/javascript"></script>
<form id="form1" runat="server">
<CR:CrystalReportViewer ID="CrystalReportViewer1" runat="server" AutoDataBind="true" OnInit="CrystalReportViewer1_Init" />
其中黄色部分加粗并圈黄的是新加的部分。类型为CrystalReportViewer的组件在工具箱拖过来的如图:
然后去页面ReportPrintDemo1.aspx的对应逻辑类ReportPrintDemo1.aspx.cs编写报表数据源的绑定,其中以下紫色圈起来的部分比较重要。实现了加载我们刚刚建好的报表文件并将查询结果填到报表文件。最后将界面报表组件和报表数据关联起来。完整代码如下:
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);
SqlDataAdapter sda = new SqlDataAdapter("select * from table_2 order by student_id", conn);
ReportDocument rd = new ReportDocument();
rd.Load(Server.MapPath(@"Report\PrintDemo1\CrystalReportDemo1.rpt"));
//绝对路径加载 //rd.Load(@"E:\Documents\Code\ASPDNet\WebStudy2\Report\PrintDemo1\CrystalReportDemo1.rpt");
this.CrystalReportViewer1.ReportSource = rd;
formula 抑制显示字段值,如下以Basix语法为例 指定默认不显示,满足条件后formula为false时才显示
if {table_2.sex} = "gril" and {table_2.age} > 5 then