Asp.Net中使用水晶报表(下)
2024-07-10 12:56:24
供稿:网友
 
使用push模式 
  我们采用下面的几步使用push模式执行水晶报表:
  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方法中使用下面的子函数:
vb.net代码:
  sub bindreport()
    dim myconnection as new sqlclient.sqlconnection() 
    myconnection.connectionstring= "server= (local)/netsdk;database=pubs;trusted_connection=yes"
    dim mycommand as new sqlclient.sqlcommand()
    mycommand.connection = myconnection
    mycommand.commandtext = "select * from stores"
    mycommand.commandtype = commandtype.text
    dim myda as new sqlclient.sqldataadapter()
    myda.selectcommand = mycommand
    dim myds as new dataset1()
    '这就是我们在设计模式上使用的dataset 
    myda.fill(myds, "stores") 
    '你不得不使用与你前面dataset相同名字。
    dim orpt as new crystalreport1()
    ' 水晶报表绑定
    orpt.setdatasource(myds)
    ' 设定水晶报表的reportsource
    crystalreportviewer1.reportsource = orpt
  end sub
 
c#代码:
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模式创建的文件时,水晶报表准确地打开所需要的数据,下面是执行导出功能的代码:
c#代码:
vb.net代码:
private sub button1_click(byval sender as system.object, byval e as system.eventargs) handles button1.click
  dim myreport as crystalreport1 = new crystalreport1()
  '注意:这里我们建立一个strong-typed的水晶报表实例。
    dim diskopts as crystaldecisions.shared.diskfiledestinationoptions = new crystaldecisions.shared.diskfiledestinationoptions()
    myreport.exportoptions.exportdestinationtype = crystaldecisions.[shared].exportdestinationtype.diskfile
  ' 导出成为其它文件时也需要这个选项
  ' 如microsoft exchange, mapi等. 
    myreport.exportoptions.exportformattype = crystaldecisions. [shared].exportformattype.portabledocformat
  '这里我们导出成为.pdf格式文件,你也能选择上面的其它类型文件
    diskopts.diskfilename = "c:/output.pdf"
  '如果你不指定确切的目录,那么文件就会保存到[windows]/system32目录中去了
    myreport.exportoptions.destinationoptions = diskopts
  '水晶报表文件不包含直接的filename属性,因此你不能直接指定保存的文件名
  '所以你不得不使用diskfiledestinationoptions对象,设置它的diskfilename属性
  '为你想要的路径,最后将水晶报表的destinationsoptions属性指定为上面的diskfiledestinationoption
    myreport.export()
  '上面的代码将完成导出工作。
end sub
 
  使用push模式导出水晶报表
  当导出的报表是由push模式建立的时,第一步就是通过编程建立连接并组装dataset,设置报表的的setdatasource属性。再下面的步骤就有pull模式一样的了。