C#水晶报表的使用_第1页
C#水晶报表的使用_第2页
C#水晶报表的使用_第3页
C#水晶报表的使用_第4页
C#水晶报表的使用_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

C#水晶报表的使用在使用自带的水晶报表时,请注册,否则只能使用30次使用CrystalReportViewer进行预览CrystalReportViewer控件允许在应用程序中查看CrystalReport。ReportSource属性用于设置要查看哪个报表。该属性设置之后,报表显示在查看器中。报表源可以是ReportDocument、报表文件的路径,也可以是强类型报表。打开''工具箱〃,并将一个CrystalReportViewer拖到窗体上,我们命名为rptVew。通过拖放操作将Windows窗体查看器调整到希望的大小并将其移动到所需位置。当运行应用程序时,报表将显示在查看器中。创建新报表指向''添加〃,单击''添加新项〃。⑵在''添加新项〃对话框中,从''模板〃区域选择CrystalReport,将报表命名为rptClient,单击''打开〃。⑶在CrystalReport库中,选择下列选项之一:使用报表专家->指导您完成报表的创建过程,并将您的选择添加到CrystalReportDesigner。作为空白报表->打开CrystalReportDesigner。。.来自于现有的报表->创建新报表,它与指定的另一报表设计相同。注意CrystalReport库包含许多专家,可以指导您完成数个特定类型报表的创建工作。您可能希望使用专家来创建最初的报表,以确定哪种报表构造方法适合您的需要。单击''确定〃按钮。如果选择使用''报表专家〃,便会出现''报表专家〃对话框,并带有数据资源管理器。为每个文件夹选择所需数据,完成''报表专家〃选项卡界面上的操作,然后单击''完成〃来访问CrystalReportDesigner和您的报表。是否需要动态设置数据源?CrystalReports通过数据库驱动程序与数据库连接。每个驱动程序都被编写为可处理特定数据库类型或数据库访问技术。拉和推模型,为了向开发人员提供最灵活的数据访问方法,CrystalReports数据库驱动程序被设计为可同时提供数据访问的拉模型和推模型。拉模型pull:在拉模型中,驱动程序将连接到数据库并根据需要将数据'拉〃进来。使用这种模型时,与数据库的连接和为了获取数据而执行的SQL命令都同时由CrystalReports本身处理,不需要开发人员编写代码。如果在运行时无须编写任何特殊代码,则使用拉模型。推模型push:相反,推模型需要开发人员编写代码以连接到数据库,执行SQL命令以创建与报表中的字段匹配的记录集或数据集,并且将该对象传递给报表。该方法使您可以将连接共享置入应用程序中,并在CrystalReports收到数据之前先将数据筛选出来。4)从ADO.NET数据集制作报表从数据库创建数据集对象在项目中新建一个架构文件:在解决方案资源管理器中,右击项目名,指向'添加〃,然后单击''添加新项〃。在'添加新项〃对话框的''类别〃区域,展开文件夹,然后选择''数据〃。在''模板〃区域选择''数据集〃。接受默认名称Dataset1.xsd。这就创建了一个新的架构文件(Dataset1.xsd),以后将用它来生成强类型数据集。该架构文件将显示在ADO.NET数据集设计器中。指定数据库位置:在服务器资源管理器中,右击''数据连接〃并选择''添加连接〃。在''数据链接属性〃对话框中,单击''提供程序〃选项卡,然后选择一个提供程序(例如MicrosoftOLEDBProviderforSQLServer)。单击''连接〃选项卡,然后指定您的数据库所在位置。在所需位置输入服务器和登录信息。单击''确定〃按钮。此时,您的数据库及其表和字段就出现在服务器资源管理器的''数据连接〃节点下面。在解决方案资源管理器中,双击Datasetl.xsd(如果它尚不是活动视图)。Datasetl.xsd现在应显示在''数据集〃选项卡中。若要为数据集建立架构,请将需要的表从服务器资源管理器中拖动到Dataset1.xsd的''数据集〃选项卡上。单击''保存Datasetl.xsd’^保存''Datasetl.xsd'^件。在“生成〃菜单上,单击''生成〃为项目生成数据集对象。ADO.NET数据集对象提供数据的描述,从它可以向Crystalreport添加表。使用CrystalReportDesigner中的''数据库专家〃从ADO.NET数据集对象添加表。请在使用''报表专家〃创建新报表时调用''数据库专家〃。或者,要从一个已经使用ADO.NET建立好的报表中访问''数据库专家〃,请在ReportDesigner中右击,指向''数据库〃,然后单击''添加/删除数据库〃。将报表连接到ADO.NET数据集对象(1)在“数据库专家〃中,展开''项目数据〃文件夹。⑵展开''ADO.NET数据集‘文件夹。选择所需数据集对象。例如,如果当时使用的是从项目''WindowsApplicationl”的架构文件''Datasetl.xsd〃中生成的数据集对象,则应该选择''WindowsApplicationl.Datasetl”。选择要向报表中添加的表,和使用其他数据源一样。动态改变数据源的代码DataSetdsdataSet=newDataSet();rptClient()oRpt=newrptClient();//已建立的报表rptClientOleDbDataAdapterda=newOleDbDataAdapter("select*fromTableName",conn);da.Fill(dsdataSet,"TableName");〃使用''报表引擎〃对象模型将填充的数据集,传递给报表oRpt.SetDataSource(dsdataSet.Tables(0));〃将带有数据的报表对象绑定到Windows窗体查看器,rptVew(CrystalReportViewer控件)rptVew.ReportSource=oRpt;注意FillDataSet方法可连接到指定的数据库,提取数据,然后断开数据库连接。如果您希望将数据库中的多个表添加到报表中,请使用SQLJOIN语句将这些表联接在一起;然后在FillDataSet方法中指定一个结果表。创建主从报表在报表中,有许多报表是主从表结构,比如订单与订单商品明细,订单是一个表中的一条记录,而分录是另一个表中的多条记录,两个表通过一个字段关联起来,这种报表可利用其分组功能实现。(1)新建一个工程⑵往FORM1中添加一个CrystalReportViewer控件(3)在服务器资源管理器中连接到SQLSERVER2000上的Northwind数据库(4)添加一个数据集Dataset1,将服务器资源管理器中的Orders和OrderDetails加入到数据集中。添加一个水晶报表,使用报表专家,在项目数据中选择“ADO.NET数据集〃,插入表Orders和OrderDetails,“链接〃中是关联字段的链接,在''字段〃中选择要显示的主表和明细表的字段,组中选择分组依据为Orders表OrdersID字段,总计,图表,选择(可进行筛选),样式(可设置报表标题),可自行设置。设置完后,点击完成。在报表设计器中调整需要显示的字段的位置、宽度等。在窗口中添加代码。publicPrintForm(){InitializeComponent();OleDbConnectionconn=newOleDbConnection("datasource=PMSERVER;initialcatalog=Northwind;userid=sa;password=sa");Dataset1()ds=newDataset1();OleDbDataAdapterda1=newOleDbDataAdapter("select*fromorders",conn);da1.Fill(ds,"orders");OleDbDataAdapterda2=newOleDbDataAdapter("select*from[OrderDetails]",conn);da2.Fill(ds,"OrderDetails");CrystalReport1oCR=newCrystalReport1();oCR.SetDataSource(ds);this.crystalReportViewerl.ReportSource=oCR;}(8)运行程序3、水晶报表登陆失败usingCrystalDecisions.Shared;〃声明所需变量。TableLogOnInfologOnInfo=newTableLogOnInfo();〃对报表中的每个表依次循环。for(inti=0;i<Report.Database.Tables.Count-1;i++){〃设置当前表的连接信息。logOnInfo.ConnectionInfo.ServerName=serverNameTxt.Text;logOnInfo.ConnectionInfo.DatabaseName=dbNameTxt.Text;logOnInfo.ConnectionInfo.UserID=userNameTxt.Text;logOnInfo.ConnectionInfo.Password=passwordTxt.Text;Report.Database.Tables[i].ApplyLogOnInfo(logOnInfo);}注意受密码保护的MicrosoftAccess和Paradox等PC数据库也使用该方法,但LogOnInfo.ServerName为数据文件的路径,LogOnInfo.DatabaseName要保留为空。TableLogOnInfo是属于CrystalDecisions.Shared命名空间的成员。要添加引用:usingCrystalDecisions.Shared;。4、水晶报表应用程序的发布1)安装部署安装部署时,把水晶报表的msm打进去,注册到服务器,要部署使用CrystalReportsforVisualStudio.NET2003的程序,首先,找到以下7个文件(你可以'C:\ProgramFiles\CommonFiles\MergeModules'文件夹下找到):Crystal_Database_Access2003.msmCrystal_Database_Access2003_chs.msmCrystal_Managed2003.msmCrystal_Managed2003_chs.msmCrystal_regwiz2003.msmVC_User_CRT71_RTL_X86_---.msmVC_User_STL71_

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论