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