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

2024-03-19 04:18

本文主要是介绍使用VS.NET向水晶报表中的存储过程传递参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 方法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");

直接加载报表。

 

 

 

 

这篇关于使用VS.NET向水晶报表中的存储过程传递参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/824766

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期