VS2005下水晶报表实现动态数据源绑定

本文转自:http://www.cnblogs.com/VS2008/archive/2006/05/21/405488.html 原作者:一代风华
本文是所有此类文章中写的最好的,推荐相关开发者阅读参考



  之前在论坛中经常有人问起在 VS2005 中使用水晶报表( Crystal Report 10 )如何用 DataSet 实现动态的数据源绑定?
  关于这个问题我研究了一下,找到了新的解决方案。
    在以前 VS2003 中可以采用 PUSH 模式推报表,可以用如下的代码实现:        
   

 

         con = new SqlConnection(Session["SQLCONNECTION"].ToString());
         strSql 
= "SELECT * FROM htOrder";
         scm 
= new SqlCommand(strSql, con);
         sda 
= new SqlDataAdapter(scm);
         ds 
= new DataSet();
         sda.Fill(ds, 
" order ");
         rptOrder.SetDataSource(ds.Tables[
"order"]);
         crOrder.ReportSource 
= rptOrder;    

        
        VS2005中不再支持“embedded report”嵌入式报表,只能采用非嵌入式报表的方法拉数据,下面是典型的代码:
    

     // 绑定报表数据
             private   void  BindCrystalReports()
        {
                
string  path1  =  Server.MapPath( " ~\\Report\\ " );
                
string  path2  =  path1  +   " repOrder.rpt " ;
                ReportDocument repDoc 
=   new  ReportDocument();
                repDoc.Load(path2);
                SetDBLogonForReport(repDoc);          
// 设置数据登录信息
                crOrder.ReportSource  =  repDoc; 
                
string  selectionFormula  =   " {htOrder.htID} = "   +  txtHtID.Text.Trim(); // 设置报表数据筛选公式
                repDoc.DataDefinition.RecordSelectionFormula  =  selectFormula;
                crOrder. DataBind ();     
        }
        
// 设置登录信息
         private   void  SetDBLogonForReport(ReportDocument reportDocument)
    {
        
try
        {
                ConnectionInfo connectionInfo 
=   new  ConnectionInfo();
                connectionInfo.ServerName 
=  ConfigurationManager.AppSettings[ " ServerName " ];
                connectionInfo.DatabaseName 
=  ConfigurationManager.AppSettings[ " DatabaseName " ];
                connectionInfo.UserID 
=  ConfigurationManager.AppSettings[ " UserID " ];
                connectionInfo.Password 
=  ConfigurationManager.AppSettings[ " Password " ];
                Tables tables 
=  reportDocument.Database.Tables;
                
foreach  (CrystalDecisions.CrystalReports.Engine.Table table  in  tables)
           {
                    TableLogOnInfo tableLogonInfo 
=  table.LogOnInfo;
                    tableLogonInfo.ConnectionInfo 
=  connectionInfo;
                    table.ApplyLogOnInfo(tableLogonInfo);
                }
        }
           
catch
      {
                lblNote.Text 
=   " <script>alert('数据库登录信息不正确!');</script> " ;
           }
}

               
        这种方式是不是太频繁琐了,在数据结构更改或者查询条件发生变化时必须要再次更改报表设置,那么在VS2005中水晶报表有没有更简洁的方法呢?最好不用写代码就能搞定呢?有,那就是新的数据绑定控件CrystalReportSource,这个控件与SqlDataSource数据源绑定控件一起连用就可以用SQL表达式作数据源推数据了。下面是实现的步骤:

        1. 建立水晶报表,注意报表要用OLE DB ADO方式连接数据源,这样可以省去报表登录窗口的弹出。
        2. 在设计视图中拖拉报表控件CrystalReportViewer,点击右上角智能标签设置报表数据源,选择报表文件,自动生成CrystalReportSource,这时在设计视图中将显示出报表界面,水晶报表将自动用初始数据填充报表字段。注意这里有个小Bug,如果报表在子目录中,选择报表文件将自动用相对路径表示,这时报表显示会出错,应改成绝对路径才可以。
            <Report FileName="report\rptOrder.rpt">这里应改成:<Report FileName="..\report\rptOrder.rpt">
        3.拖拉一个数据源控件SqlDataSource(也可以用ObjectDataSource),按向导生成数据源,这里可以筛选数据,根据情况选择各类数据源。            
        4.
如何将CrystalReportSourceSqlDataSource两个控件连接在一起呢?可以这样:选择CrystalReportSource控件点击右侧属性中数据栏,再点击Report选择DataSource,在这个数据源集合编辑器选择数据源指定报表名称即可。(下面的Parameters是用来选择报表参数用的)

        经过这几个步骤,就可以运行程序显示报表啦,怎么样不用写一句代码吧?

具体代码可参考如下:

 

< CR:CrystalReportViewer  ID ="crOrder"  runat ="server"  AutoDataBind ="True"   ReportSourceID ="ReportSourceOrder"   BestFitPage ="False"  DisplayToolbar ="False"  DisplayGroupTree ="False"  Height ="1042px"  Width ="775px"  EnableParameterPrompt ="False"   />         
        
< CR:CrystalReportSource  ID ="ReportSourceOrder"  runat ="server" >
            
< Report  FileName ="..\report\rptOrder.rpt" >                            
                    
< DataSources >
                            
< CR:DataSourceRef  DataSourceID ="SqlDataSourceOrder"  TableName ="htOrder"   />
                    
</ DataSources >
              
</ Report >
        
</ CR:CrystalReportSource >
        
< asp:SqlDataSource  ID ="SqlDataSourceOrder"  runat ="server"  ConnectionString ="<%$ ConnectionStrings:cc_2005 %>"
            SelectCommand
="SELECT * FROM [htOrder] " ></ asp:SqlDataSource >

你可能感兴趣的:(数据源)