我的番茄炒蛋
生活如此精彩,挑战无处不在!

导航

 
在设计水晶报表的过程中,对于传值给水晶报表,发现网上很难找到比较全的资料,所以特对此内容进行一下总结,供大家分享.

    如果没有为水晶报表传值,其显示的结果通常为对应数据库表的所有记录,那么怎样才能让水晶报表只显示用户需要的数据呢?这就是给水晶报表传值的问题.解决这个问题有两种方式:给水晶报表传递查询的值和给水晶报表传递用户查询的结果.

    1、给水晶报表传递查询值
    要实现给水晶报表传递查询值,首先在设计报表时,需要在Parameter Fields中添加参数字段(方法为:在Field Explorer面板中,鼠标在Parameter Fields上游击,选择New,自己取一个名字.比如我们数据库中存在一个'日期'的字段,我们添加一个Month用来查询满足Month的值).然后点击菜单项Crystal Reports->Report->Selection Formula->Record,弹出Formula Workshop对话框,编辑查询语句如:Month({tbl_SellMain.日期})={?Month}.{tbl_SellMain.日期}可以通过连接中双击日期字段得到.这样水晶报表设计就完成了.Main Report Preview可以查看报表的显示结果,根据提示输入Month的值后,可以看到显示结果中只有满足用户输入条件的结果了.

    如果在C#中不添加任何代码,在每次显示报表时,都会提示输入Month的信息,那么怎样在程序中传入Month的值呢?

    在C#中添加如下代码.
    using CrystalDecisions.Shared;
    //指定报表对应的报表文件
            crystalReportViewer1.ReportSource = path; //crystalReportViewer1为添加在窗体中的CrystalReportViewer.

            //给报表传值,获得满足条件的查询结果
            ParameterFields paramFields = crystalReportViewer1.ParameterFieldInfo;
        
            ParameterField paramMonth = paramFields["Month"];

            ParameterValues curValues=paramCompany.CurrentValues;
            ParameterDiscreteValue discreteValue = new ParameterDiscreteValue();
            discreteValue.Value = 5;    //5为用户设置的查询,此处表示查询的月份为5月
            curValues.Add(discreteValue);

            crystalReportViewer1.ParameterFieldInfo = paramFields;
这样,显示的结果就仅为5月份的数据.

    2、给水晶报表传递用户查询的结果
    给水晶报表传递查询结果的方式比较直观,在报表设计时也只需要设计好要显示的字段即可.其步骤为:通过SqlDataAdapter获得查询数据,然后填充到一个DataTable对象,然后用此对象填充ReportDocument对象,最后将水晶报表的ReportSource指定为此ReportDocument对象.

    在C#中实现的代码为:
    //生成查询语句
            string select="select * from tbl_SellMain where";
            if (txtName.Text.Trim() != "")
                select += " 公司名称='" + txtName.Text.Trim() + "' and";
            select += " Year(日期)=" + cmbYear.Text + " and";
            select += " Month(日期)=" + cmbMonth.Text;

            SqlConnection conn = new SqlConnection("Data Source=.;Initial Catalog=GYHR;Integrated Security=True");
            SqlDataAdapter da = new SqlDataAdapter(select, conn);
            DataTable dt=new DataTable();
            da.Fill(dt);

            //这里必须事先申明一个ReportDocument对象   Report,同时加载数据报表   
            ReportDocument rd = new ReportDocument();
            //获取.rpt文件真实路径   
            string path;
            rd.Load(path);
            rd.Database.Tables[0].SetDataSource(dt);   //对应报表设计的第一个数据表
            crystalReportViewer1.ReportSource = rd;
            //crystalReportViewer1.PrintReport();       打印
posted on 2008-05-07 11:54  bluesky  阅读(1625)  评论(0编辑  收藏  举报