Winform RDLC报表(数据库连接、报表函数使用、动态表头)

2023-12-30 20:04

本文主要是介绍Winform RDLC报表(数据库连接、报表函数使用、动态表头),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • NuGet安装库
  • 数据库连接
  • 报表设计
    • 报表引用
    • 添加报表
  • 数据集设计
    • 方法一手动添加
    • 方法二——连接数据库添加
  • 关联报表与数据集
    • 表格数据与数据集数据设计
      • 表格格式、字体设计
      • 报表数据字段绑定
  • Winform 使用报表控件
  • 数据库填充数据集
    • 从数据库获取与数据源相同字段的数据
  • 动态表头设计
    • 添加表头参数
    • 绑定表头参数
    • 表头数据添加与绑定
  • 表格常用函数
    • 行数自增长
    • 表格颜色
      • 表格颜色表达式
  • 行、列可见性

NuGet安装库

报表相关
在这里插入图片描述
数据库相关
在这里插入图片描述
安装完后
在这里插入图片描述

数据库连接

其中Sql执行语句是选择报表所需要的字段。

 /// <summary>/// 数据库连接与SQL语句执行/// </summary>/// <param name="connectionString">连接语句</param>/// <param name="strSql">Sql执行语句</param>/// <returns></returns>public DataSet ConnReadSql(string connectionString,string strSql){DataSet dataSet = new DataSet(); using (SqlConnection connection = new SqlConnection(connectionString)){               try{connection.Open();SqlDataAdapter command = new SqlDataAdapter(strSql, connection);command.Fill(dataSet, "ds");}catch (System.Data.SqlClient.SqlException ex){throw new Exception(ex.Message);}}return dataSet;}

报表设计

报表引用

扩展——联机
搜索RDLC
在这里插入图片描述
如果下载太慢,点击"详细信息",在浏览器下载,或者更快的可以在迅雷下载,下载完成后关闭所有VS进程,进行安装包的安装。
在这里插入图片描述

添加报表

右击项目——添加——新建项——报表
在这里插入图片描述

数据集设计

在这里插入图片描述

方法一手动添加

在工具箱中找到数据集工具,拉一个DataTable到数据集
在这里插入图片描述
“Ctrl+L”快捷创建DataTable行数,添加字段需要与数据库获取字段一致。
在这里插入图片描述

方法二——连接数据库添加

在工具箱中找到数据集工具,拉一个DataTable到数据集,会弹出来配置向导。
点击新建连接
在这里插入图片描述
输入服务器后,在下拉框中选择所需数据库,点击测试连接,显示成功后,点击确定。
在这里插入图片描述
在这里插入图片描述
点击下一步
在这里插入图片描述
点击确定
在这里插入图片描述
点击下一步
在这里插入图片描述
这里直接点击“查询生成器”
在这里插入图片描述
点击添加
在这里插入图片描述
在这里插入图片描述
点击完成
在这里插入图片描述

http://t.csdnimg.cn/cks1x

在这里插入图片描述
在这里插入图片描述

关联报表与数据集

在工具栏的报表项目下面拉取表
在这里插入图片描述
之后会出现报表数据窗口,如果没有,快捷键ctr +alt+D
在这里插入图片描述
点击数据集——添加数据集
1.名称是后续代码要用到的参数名字
2.点击该项目设计的数据源,下方会出现对应可用数据集,选择需要的数据集,点击确定。
在这里插入图片描述

表格数据与数据集数据设计

表格格式、字体设计

右击表格——文本框属性

  1. 设置字体——微软雅黑(否则后期中文会出现乱码)
    在这里插入图片描述

  2. 根据需求设置对其样式
    在这里插入图片描述
    3.报表表格格式在数量众多的时候可以设计一个,后面的进行复制粘贴也会把格式带过去,或者在插入列或者插入行等操作时,沿用最近一个的所有格式

报表数据字段绑定

右击表格框——表达式——点击字段(如果字段没有,尝试刷新数据集之后重新点开字段)——双击值列表下的字段

在这里插入图片描述在这里插入图片描述

Winform 使用报表控件

点击工具箱拉去ReportViewer 到窗体显示报表位置,本文该控件名称为reportViewer2

在这里插入图片描述

数据库填充数据集

从数据库获取与数据源相同字段的数据

Sql语句执行函数

         /// <summary>/// 数据库连接与SQL语句执行/// </summary>/// <param name="connectionString">连接语句</param>/// <param name="strSql">Sql执行语句</param>/// <returns></returns>public DataSet ConnReadSql(string connectionString,string strSql){DataSet dataSet = new DataSet(); using (SqlConnection connection = new SqlConnection(connectionString)){               try{connection.Open();SqlDataAdapter command = new SqlDataAdapter(strSql, connection);command.Fill(dataSet, "ds");}catch (System.Data.SqlClient.SqlException ex){throw new Exception(ex.Message);}}return dataSet;}

数据库填充数据集

 private void Form1_Load(object sender, EventArgs e){try{string connectionString = "Server=.;Integrated Security=SSPI;Database=BRL_measurement_DB";string sql = "SELECT dateTime,normName,param1,param2,param3  FROM View_Data_Qualification";DataSet dataSet = new DataSet();dataSet = ConnReadSql(connectionString, sql);///---向报表绑定数据源this.reportViewer2.ProcessingMode = ProcessingMode.Local;this.reportViewer2.LocalReport.DataSources.Add(new ReportDataSource("DataSet1001", dataSet.Tables[0]));///---向报表查看器指定显示的报表this.reportViewer2.LocalReport.ReportPath = @"..\..\Report1.rdlc";this.reportViewer2.LocalReport.Refresh();this.reportViewer2.RefreshReport();}catch (Exception er){MessageBox.Show(er.Message.ToString());}}

在这里插入图片描述

动态表头设计

项目中如果表头需要中英文转换等需求,可以考虑动态表头设计

添加表头参数

打开报表数据——点击参数——添加参数
注意:该部位添加的参数需要与程序中参数名相同
在这里插入图片描述

绑定表头参数

右击表格框——参数——双击索要显示值——表达式正确——确定
在这里插入图片描述

表头数据添加与绑定

在这里插入图片描述

 private void Form1_Load(object sender, EventArgs e){try{string connectionString = "Server=.;Integrated Security=SSPI;Database=BRL_measurement_DB";string sql = "SELECT dateTime,normName,param1,param2,param3  FROM View_Data_Qualification";DataSet dataSet = new DataSet();dataSet = ConnReadSql(connectionString, sql);Random random = new Random();int J = random.Next(18,21);//动态表头设计ReportParameter[] parameters=new ReportParameter[3];if (J%2==0){parameters[0] = new ReportParameter("ReportParameter1", "序号");parameters[1] = new ReportParameter("ReportParameter2", "规格");parameters[2] = new ReportParameter("ReportParameter3", "数据1");}else{parameters[0] = new ReportParameter("ReportParameter1", "Num");parameters[1] = new ReportParameter("ReportParameter2", "Specifications");parameters[2] = new ReportParameter("ReportParameter3", "Data1");}///---向报表绑定数据源this.reportViewer2.ProcessingMode = ProcessingMode.Local;this.reportViewer2.LocalReport.DataSources.Add(new ReportDataSource("DataSet1001", dataSet.Tables[0]));///---向报表查看器指定显示的报表this.reportViewer2.LocalReport.ReportPath = @"..\..\Report1.rdlc";//动态表头设置this.reportViewer2.LocalReport.SetParameters(parameters);this.reportViewer2.LocalReport.Refresh();this.reportViewer2.RefreshReport();}catch (Exception er){MessageBox.Show(er.Message.ToString());}}

在这里插入图片描述
在这里插入图片描述

表格常用函数

行数自增长

=RowNumber(Nothing)
在这里插入图片描述
在这里插入图片描述

表格颜色

选中一行更改颜色
在这里插入图片描述

表格颜色表达式

点击文本框属性——填充——点击函数Fx——点击函数IIF——选择要判断的字段——赋值颜色。
该函数表明:如果param1值为真则为第一个参数,为假则为第二个参数,为空不做判断
在这里插入图片描述
在这里插入图片描述

行、列可见性

单击一行或一列,选择属性——可见性——基于表达式显示或隐藏——点击Fx
=IIf(IsNothing(Fields!param3.Value),true,false)
在这里插入图片描述

这篇关于Winform RDLC报表(数据库连接、报表函数使用、动态表头)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁