首页 > 编程 > .NET > 正文

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模式一样的了。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表