[水晶报表]水晶报表创建以及调用方法

原创 2009年10月15日 09:57:00

ASP.NET2.0/3.5/4.0水晶报表创建以及调用方法
1. 创建CrystalReport(网站中添加新项CrystalReport,或者单独开发水晶报表)放到指定目录
2、使用向导创建报表(如何创建请参考其它资料)Suppliers.rpt
3、VS.NET2005/2008/2010布局报表,添加删除字段.
4、回到页面,选择控件CrystalReportViewer将其放到页面上。
5、设置CrystalReportViewer1数据源(介绍两种方法)。

引入

using CrystalDecisions.Shared;
using CrystalDecisions.CrystalReports.Engine;
using CrystalDecisions.ReportSource;

第一种: 拉模式

    <CR:CrystalReportViewer ID="CrystalReportViewer1" runat="server" 
            AutoDataBind="True" GroupTreeImagesFolderUrl="" Height="1202px" 
         ReportSourceID="CrystalReportSource1" ToolbarImagesFolderUrl="" 
         ToolPanelWidth="200px" Width="1104px"   ToolPanelView="None" />
     <CR:CrystalReportSource ID="CrystalReportSource1" runat="server">
         <Report FileName="..\..\ERP\Reports\ZMQuotation.rpt">
         </Report>
     </CR:CrystalReportSource>

CS:

      CrystalReportSource1.ReportDocument.SetDatabaseLogon(PublicVar.ShatdbID, PublicVar.shatdbPW, PublicVar.ShatdbDS, PublicVar.Shatdb);//取得公共变量
      CrystalReportSource1.ReportDocument.SetParameterValue("@ItemP", "no");
      CrystalReportSource1.ReportDocument.SetParameterValue("@descriptionP", "no");
      CrystalReportViewer1.DataBind();

     注释:PublicVar.ShatdbID 用户名, PublicVar.shatdbPW 密码, PublicVar.ShatdbDS 数据源(机器名或者IP), PublicVar.Shatdb 数据库名
          CrystalReportSource1.ReportDocument.SetParameterValue("@ItemP", "no"); 报表参数
     这种方法通常第一次登陆的时候就需要给定一个默认参数(如果带参数)
第二种:推模式

        string DBConfig_sql = PublicVar.strCon;
        DataSet ds = new DataSet();
        SqlConnection sqlCon = new SqlConnection(DBConfig_sql);
        SqlCommand sqlCmd = new SqlCommand(sql, sqlCon);
        SqlDataAdapter sqlAd = new SqlDataAdapter();
        sqlAd.SelectCommand = sqlCmd;
        sqlAd.Fill(ds, "sql");
        //如果绑定报表
        //注意此处必需指明Dataset中的表的名称,否则会提示“您请求的报表需要更多信息.”
        CrystalReportSource1.ReportDocument.SetDataSource(ds.Tables["sql"]);
        CrystalReportViewer1.ReportSource = CrystalReportSource1;
        CrystalReportViewer1.DataBind();
        //未绑定
        String path = Server.MapPath("HandQty.rpt");
        CrystalReportViewer1.Load(path);
        CrystalReportSource1.ReportDocument.SetDataSource(ds.Tables["sql"]);
        CrystalReportViewer1.ReportSource = CrystalReportSource1;
        CrystalReportViewer1.DataBind();

存储过程:

        ReportDocument myReport = new ReportDocument();
        SqlParameter[] parms = new SqlParameter[1];
        parms[0] = new SqlParameter("@id", SqlDbType.Int);
        parms[0].Value = id; 
        DataSet ds = new DataSet();
        ds = DataAccess.DataAccessSHDB.GetTableByStore("project", parms).DataSet;
 
        CrystalDecisions.CrystalReports.Engine.ReportDocument doc = new CrystalDecisions.CrystalReports.Engine.ReportDocument();
        string reportPath = Server.MapPath("..//Reports//project.rpt");
        //doc.Load(@"C:/test/1.rpt");
        doc.Load(reportPath);
        doc.SetDataSource(ds.Tables[0]);
        CrystalReportViewer1.ReportSource = doc;
        CrystalReportViewer1.DataBind();

如果有时候无法刷新数据:添加如下代码即可

      CrystalReportSource1.ReportDocument.SetParameterValue("@ItemP", "no");
      CrystalReportSource1.ReportDocument.SetParameterValue("@descriptionP", "no");
      CrystalReportViewer1.DataBind();


第三种方式:

直接show在页面,不含水晶报表工具栏;

private void Print()
    {
        SampleRequest sr = new SampleRequest();
        sr.TaskCode = taskcode;
        DataSet ds = new DataSet();
        ds = sr.SampleRequestDetail();
        if (ds != null)
        {
            CrystalDecisions.CrystalReports.Engine.ReportDocument doc = new CrystalDecisions.CrystalReports.Engine.ReportDocument();
            string reportPath = Server.MapPath("..\\..\\ERP\\Reports\\SampleRequest.rpt");
            doc.Load(reportPath);
            doc.SetDataSource(ds.Tables[0]);

            CrystalReportViewer1.ReportSource = doc;
            CrystalReportViewer1.DataBind();

            string filetype = "";
            filetype = "PDF";
            string contenttype = "";
            //string myfilename = Request.MapPath(".\\") + Session.SessionID + "." + filetype;//目录地址 注意反义字符
            string myfilename = "E:\\Report\\SAL\\" + "SampleRequest" + Baseclass.getLongData().ToString() + "." + filetype;
            CrystalDecisions.Shared.DiskFileDestinationOptions mydiskoptions = new CrystalDecisions.Shared.DiskFileDestinationOptions();
            mydiskoptions.DiskFileName = myfilename;
            CrystalDecisions.Shared.ExportOptions myExportOptions = new ExportOptions();//oCR.ExportOptions; 
            myExportOptions.DestinationOptions = mydiskoptions;
            myExportOptions.ExportDestinationType = CrystalDecisions.Shared.ExportDestinationType.DiskFile;

            contenttype = "application/pdf";
            myExportOptions.ExportFormatType = CrystalDecisions.Shared.ExportFormatType.PortableDocFormat;

            doc.Export(myExportOptions); //输出报表 到服务器端的制定路径 
            Response.ClearContent();     //清空页面 
            Response.ClearHeaders();
            Response.ContentType = contenttype;
            Response.WriteFile(myfilename);//直接写入页面,页面平铺 可实现在线阅读功能
            Response.Flush();
            Response.Close();
        }
        else
        {
            JScript.Alert("没有找到记录", this.Page);
        }
    }


 


 

版权声明:本文为博主原创文章,未经博主允许不得转载。

水晶报表制作实例

水晶报表貌似是比较“古老”的报表技术了,它是由SAP公司开发的报表产品,通过安装开发包可以在VS中集成Crystall Reports设计器。通过可视化的设计和操作,可以完成报表的制作。正好最近有空帮...
  • guwei4037
  • guwei4037
  • 2015年04月22日 15:23
  • 7597

[水晶报表]水晶报表的使用经验和资料总结

水晶报表的使用经验和资料总结资料: Asp.Net中使用水晶报表(上) www.dotnet8.com 2002-9-6 DotNet吧[HTML]在我们对VS.Net中的水晶报表(Cryst...
  • david_520042
  • david_520042
  • 2016年08月17日 09:30
  • 2627

【水晶报表之图片篇-c】 CR 11版本动态加载的另一种简单方案

2005年我在《水晶报表中如何动态加载图片(图片文件版本及数据库版本)》 提供的方法中,用了编程的方法,虽然也实现了,但是比较繁琐 地址: http://www.cnblogs.com/baby...
  • findsafety
  • findsafety
  • 2015年03月24日 16:09
  • 2799

JAVA水晶报表从环境搭建到创建动态水晶报表

首先第一步贴上项目截图(少了一个rpt_report文件夹,因为是网上的所以这里没加,各位可以加下):声明该项目是网上下载。(比较简单,纯属偷懒,有现成环境)。可以自己修改,需要注意的就是蓝色标记的地...
  • lovin_fang
  • lovin_fang
  • 2014年11月19日 13:52
  • 1574

CristalReport(水晶报表)插件整合Eclipse开发

CristalReport(水晶报表) 本身的安装版本是.net专用的开发报表的工具,但目前推出了Eclipse插件,便可以进行Java开发报表了,虽然我们项目没有采用(貌似是因为不支持垂直居中,是不...
  • rainyspring4540
  • rainyspring4540
  • 2015年09月01日 09:38
  • 1925

水晶报表自定义函数进行代码重用 -日期大写

   一般我们可以使用公式来实现一些特殊的功能,但是对于一些需要重复处理的情况 可以使用自定义函数来实现 进入公式编辑界面 ,可以看到在左上角有两个项目: 报表自定义函数和储备库自定...
  • xpx1290
  • xpx1290
  • 2016年06月17日 11:57
  • 533

为水晶报表(含子报表)绑定数据

本Demo为http://topic.csdn.net/u/20111202/11/4965b533-3102-410f-8de0-9a0eedada681.html?55467 提供。  我们...
  • SunCherryDream
  • SunCherryDream
  • 2015年05月05日 17:56
  • 1176

Vs2010中水晶报表引用及打包

转自:http://yunhaifeiwu.iteye.com/blog/1172283 Vs2010中水晶报表引用 在sap官网中下载支持vs 2010中的水晶报表组件。具体地址: ...
  • jun471537173
  • jun471537173
  • 2013年04月17日 16:36
  • 4246

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

水晶报表VS2010版IDE安装标准版SAP Crystal Reports, version for Visual Studio 2010 - Standard: 下载地址: http://dow...
  • jsjpanxiaoyu
  • jsjpanxiaoyu
  • 2015年01月03日 10:27
  • 11209

VS2010下水晶报表的使用总结-从安装到使用到部署,有图有真相

VS2010下水晶报表的使用总结-从安装到使用到部署,有图有真相。 公司要做一个有关水晶报表的打印,让我自己研究怎么使用,整整折磨我好几天。做了有关winform和Web两种方式的。我的开发环境是V...
  • ping0926
  • ping0926
  • 2013年05月31日 14:03
  • 2677
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[水晶报表]水晶报表创建以及调用方法
举报原因:
原因补充:

(最多只允许输入30个字)