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

标签: 报表 asp.net dataset sql string path
3633人阅读 评论(0) 收藏 举报
分类:

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);
        }
    }


 


 

1348118583_4652.jpg
查看评论

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

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

真正的水晶报表详细使用步骤

ASP.NET中水晶报表的使用       报表类型我们在设计报表时,最好使用Crystal Reports的报表向导,它会按照不同类型的报表给以不同的指导,帮助您正确得设计出您想要的报表雏形,此处就...
  • sunchaohuang
  • sunchaohuang
  • 2008-05-10 08:25:00
  • 3158

水晶报表使用经验总结

转自    http://blog.csdn.net/louisp/archive/2005/10/27/517621.aspx   资料:Asp.Net中使用水晶报表(上)www.dotnet8.c...
  • add8849
  • add8849
  • 2005-11-28 09:13:00
  • 15796

[水晶报表]重复记录显示一次

如:       物料                        物料说明                                                        单位  ...
  • david_520042
  • david_520042
  • 2008-10-08 14:20:00
  • 1801

水晶报表ActiveX打印设置

报表ActiveX打印设置 1、安装安全控件,操作步骤:    A、先暂时退出360安全卫士、杀毒软件、防火墙等。    B、点击控件下载并安装控件。    C、安装过程中按提示进行...
  • lovegonghui
  • lovegonghui
  • 2017-09-19 12:31:16
  • 722

水晶报表公式化字段,自定义报表

http://www.cnblogs.com/babyt/archive/2008/01/03/1024941.html 前文《在水晶报表中实现任意选择指定字段显示》中有朋友留言说是有无C#版本,最近...
  • zbssoft
  • zbssoft
  • 2010-05-13 11:08:00
  • 4234

水晶报表的推模式实现

        水晶报表是一个使用容易使用的报表,其实现方法基本由两种,一种是推模式,一种是拉模式,现在我写了一个推模式的实现,代码如下:        ReportDocument rptDoc ...
  • zhangjp
  • zhangjp
  • 2008-01-13 05:43:00
  • 2629

轻松加精确完成水晶报表对象的对齐、移动及大小调整——使用准线设计

Crystal Reports 提供准线以协助您准确地对齐、移动对象并调整报表对象的大小。准线是一些非打印线条,可以将其放在“设计”选项卡和“预览”选项卡上的任何位置以帮助对齐。它们具有对齐属性,使对...
  • haibodotnet
  • haibodotnet
  • 2003-12-02 22:00:00
  • 6785

《C#经典编程220例》.(明日科技).【带书签】-共3部分

实现<em>重复</em>高效地利用基窗体 127 实例078 尝试制作一...使用helpprovider组件<em>调用</em>帮助文件 172 实例106 使...<em>水晶报表</em>与打印 241 实例141 设计带有背景图的水晶...
  • 2018年04月16日 00:00

水晶报表分组显示

1,  水晶报表分组显示2,  1、  新建组名字段;RptWo.product_card2、  新建公式字段count({RptWo.wo_in_qty},{RptWo.product_card})...
  • mygirlandboy
  • mygirlandboy
  • 2010-06-28 19:45:00
  • 214
    个人资料
    专栏达人 持之以恒
    等级:
    访问量: 257万+
    积分: 3万+
    排名: 134
    博客专栏
    最新评论
    文章存档