PUSH-推模式:利用DataSet生产的数据源,需写代码。

   具体步骤
    
       1. 设计一个DataSet 
      2. 创建一个.rpt文件同时将其指定给上一步建立的DataSet。
     3. 在aspx页面中拖放一个CrystalReportViewer控件同时将其与前面的rpt文件建立联系。
     4. 在代码中访问数据库并把数据存入DataSet
     5. 调用DataBind方法。

     
            设计一个DataSet

             1) 右击“解决方案浏览器”,选择“添加”--“添加新项”-->“数据集”


   2) 从“服务器资源管理器”中的“SQL Server”中拖放“Stores”表(位于PUBS数据库中)。

 

  3) 此时在数据集中就会有一个Stores表的结构图。

  - .xsd文件中仅仅包含一个结构图,但是不会有任何数据在里面。

  创建 .rpt 文件 :

  4) 使用上面的介绍过的方法创建此文件,唯一的不同就是使用数据集来代替前面的直接连接数据。

  5)建立.rpt文件之后,右击“详细资料”-->"添加/删除数据库“

  6) 在”数据库专家“窗口中,展开”项目数据“(代替以前的OleDb),展开“ADO.Net数据集”--"DataSet1“,选择”Stores“表。

  7) 将”Stores"表添加到“选定的表”中,点击“OK”

  8) 使用PULL模式下的方法,建立一个WebForm

  建立一个Crystal Report Viewer 控件

  9) 建立一个Crystal Report Viewer 控件,并设定其属性,此处与PULL模式下是一致的。

  Code Behind 代码:

  10) 在Page_Load方法中使用下面的子函数:


 

private void BindReport()

{

  string strProvider = "Server=(local);DataBase=pubs;UID=sa;PWD=";

  CrystalReport1 oCR = new CrystalReport1();

  Dataset1 ds = new Dataset1();

  SqlConnection MyConn = new SqlConnection(strProvider);

  MyConn.Open();

  string strSel = "Select * from Stores";

  SqlDataAdapter MyAdapter = new SqlDataAdapter(strSel,MyConn);

  MyAdapter.Fill(ds,"stores");

  oCR.SetDataSource(ds);

  this.CrystalReportViewer1.ReportSource = oCR;

}


 注意:在上面的代码中,你得注意一下oRpt是"Strongly Typed"的报表文件。如果你需要使用"UnTyped"报表,你得使用ReportDocument对象,然后再调用报表文件。

  运行你的程序。

  11) 运行你的程序

  将报表文件导出成为其它格式

  你能够将报表文件导出成为下列格式:

      1. PDF (Portable Document Format)

      2. DOC (MS Word Document)

      3. XLS (MS Excel Spreadsheet)

      4. HTML (Hyper Text Markup Language – 3.2 or 4.0 compliant)

      5. RTF (Rich Text Format)

  使用Pull模式导出报表

  当导出使用Pull模式创建的文件时,水晶报表准确地打开所需要的数据,下面是执行导出功能的代码:

posted on 2007-12-09 03:38  小咪  阅读(381)  评论(0编辑  收藏  举报