使用VS.NET向水晶报表中的存储过程传递参数

9 篇文章 0 订阅
0 篇文章 0 订阅

 方法1,直接在报表对象上设置参数的值

  

  1.  myReport1.SetParameterValue("@time1""2008-11-01");

方法2,在reportViewer中添加参数。效果是一样的,只不过代码量不同。

 

  1. ParameterField param1 = new ParameterField();
  2.                 param1.ParameterFieldName = "@time1";parPrinter为你在报表设计器中添加的参数名   
  3.                 ParameterDiscreteValue param1_Value = new ParameterDiscreteValue();//离散值   
  4.                 param1_Value.Value = time1;
  5.                 param1.CurrentValues.Add(param1_Value);
  6. //向fields里面添加参数
  7. ParameterFields ParamFields = new ParameterFields();
  8.                 ParamFields.Add(param1);
  9.                crystalReportViewer1.ParameterFieldInfo = ParamFields;

方法3,也可以传递参数,是方法2的简化版

  1.    report1.ParameterFields["@team"].CurrentValues.AddValue(team);

另我灰常郁闷的是,搞了1天传不过去参数,原因仅仅是因为 参数前面忘记加 “@”符号(因为报表的数据源是存储过程)。天哪~~

 

 

-------------------------------------------------我是分割线------------------------------------------------------------------------------------

 

在使用水晶报表的时候也遇到了一些很有意思的事情。

 

首先,是遇到了传参数的问题,这个问题已经在上面解决了。

然后呢是遇到了弹数据库登陆窗口的问题,一开始我是将程序中查询数据库得到的DataSet作为报表的数据源的。如下:

 

  1. report1.SetDataSource(DataOperate.getReportData(time1, time2, team, type, Form1.conn));

这样写是会弹登陆窗口的,后来我把dataSource改成了DataSet.tables,如下

  1. report1.SetDataSource(DataOperate.getReportData(time1, time2, team, type, Form1.conn).Tables[0]);

这样写就不会弹登陆数据库窗口了,但是传入报表的参数在报表上面显示不出来了。根据参数查询出来的结果没错,但是就是在页面上显示不了参数。

所以在又改成这样:

    • report1.SetDataSource(DataOperate.getReportData(time1, time2, team, type, Form1.conn));
    • report1.SetDatabaseLogon("sa""sa""OMG""JetPrint");

这样不会弹数据库登陆框了,也能显示参数了。

好了,一切正常了,但是我发现这样做多此一举了,我在编辑报表的时候已经用数据专家定义好了表内容了,这里再弄一个DataSet做为数据源,那不是报表和程序本身各取了一次数据集嘛~~ 所以我又这样改了

  1. report1.Load(Application.StartupPath + "mingxibiao.rpt");
  2. report.SetDatabaseLogon("sa""sa""OMG""JetPrint");

直接加载报表。

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值