回 帖 发 新 帖 刷新版面

主题:[原创]给水晶报表传值的两种方式

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

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

    [b]1、给水晶报表传递查询值[/b]
    要实现给水晶报表传递查询值,首先在设计报表时,需要在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月份的数据.

    [b]2、给水晶报表传递用户查询的结果[/b]
    给水晶报表传递查询结果的方式比较直观,在报表设计时也只需要设计好要显示的字段即可.其步骤为:通过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();       打印

回复列表 (共2个回复)

沙发

加精鼓励~~

板凳

河北主机托管租用您的最佳选择~^0^~网悦互联

国际级☆☆☆☆超豪华机房最低保证5M,峰值能跑到10M,租用、独享、整柜、托管面谈

1.24小时工程师实时值守、随时提供不限次数的服务器重启或调试服务

2.负责运送、安装并调试接通网络端口

3.协助查找分析服务器硬件问题、为您解决问题提供帮助

4.服务器托管在具有国际级电信级标准的IDC机房里、均为网通电信骨干网带宽

5. 用户可以随时将100M共享带宽根据需要在补足差价以后随时更换成独享10M、100M

6. 机房设施一流,双路市电+ UPS +柴油发电机组

7.允许带宽免费测试24小时、合同签订并且合同金额到帐后24小时内上架

独享带宽:10M\20M\30M\40M\50M\-100M\-1G面谈

10M带宽+1台机器,100M带宽+1个柜[打包]零利润促销中~~ (数量有限赶紧联系13932197456)

河北服务器托管租用 - 石家庄网通电信机房

网悦互联-提供石家庄服务器托管租用

网悦互联咨询热线电话:0311-86666683 86666693

为了第一,唯一,我们一直在努力,用心服务,客户至上

服务器托管到底是选择本地机房还是外地机房呢?

网悦互联- 河北石家庄网通电信豪华机房,专业服务器托管、租用

石家庄想托管服务器和租用整机的朋友必看的贴子!

网悦互联、河北网通电信合作伙伴、为您提供主机托管、主机租用等全方位的服务

联系QQ: 239248293 14662231  

联系电话:0311-86666683 86666693 或 13932197456  贾嘉 

诚接各游戏河北支点,分区运营,服务器合作,游戏推广,有意者联系QQ:1111410

诚招各级代理加盟、免加盟费用、心动不如行动,加盟电话:13932197456

(机不可失,失不再来的啊!如果您心动了,那就不要犹豫,快来联系我们啊)
&华北IDC交流群:486879

我来回复

您尚未登录,请登录后再回复。点此登录或注册