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)
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/585950.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据库一般会采取什么样的优化方法?

数据库一般会采取什么样的优化方法&#xff1f; 1、选取适合的字段属性 为了获取更好的性能&#xff0c;可以将表中的字段宽度设得尽可能小。 尽量把字段设置成not null 执行查询的时候&#xff0c;数据库不用去比较null值。 对某些省份或者性别字段&#xff0c;将他们定义为e…

【并发】AtomicInteger很安全

AtomicInteger 简介与常规用法 AtomicInteger 是 Java 中 java.util.concurrent.atomic 包下的一个类。用于实现原子操作的整数。它是一个基于CAS&#xff08;Compare-And-Swap&#xff09;实现的原子整数类。它提供了一系列的原子操作&#xff0c;确保对整数的操作是原子性的&…

JavaScript(ES6)数据结构与算法之树

6. 树 文章目录 6. 树6.1 概念6.2 二叉树6.3 二叉搜索树概念代码实现插入遍历获取最值搜索删除节点 6.4 红黑树红黑树概念红黑树规则平衡原理 6.1 概念 非线性结构 n(n>0)个节点构成的有限集合&#xff0c;n0时称为空树 对于任一非空树 有一个根节点其余节点可以构成子树 …

python 中断点调试 pdb 包的介绍及使用

pdb 的简介 pdb&#xff08;python debugger&#xff09; 是 python 中的一个命令行调试包&#xff0c;为 python 程序提供了一种交互的源代码调试功能&#xff0c;其官方使用文档链接为 pdb — Python 的调试器。 pdb 的主要功能包括设置断点、单步调试、进入函数调试、查看当…

Django、Python版本升级问题大汇总

Django3.0升级到4.1,Python3.8升级到3.11.6问题大汇总 报错1:ERROR: Could not build wheels for cffi, uWSGI, which is required to install pyproject.toml-based projects ERROR: Could not build wheels for cffi, uWSGI, which is required to install pyproject.tom…

golang 图片加水印,字体文件从哪里找

鼠标左键双击此电脑图标在此电脑文本框输入电脑默认字体地址&#xff1a;C:\Windows\Fonts找到需要用到的字体文件&#xff0c;复制到指定文件夹

python企业车辆车货信息平台 s05fw

车货信息平台系统可具体分为货源方、平台方、承运方三部分。其中前端要求包含货源方&#xff1a;发布货源信息、选择承运方、司机服务评价&#xff1b;平台方&#xff1a;账户管理、货主、司机资质审核、聊天功能&#xff1b;承运方&#xff1a;车辆信息上传、个人车主发布车源…

Ubuntu Desktop 死机处理

Ubuntu Desktop 死机处理 当 Ubuntu Desktop 死机时&#xff0c;除了长按电源键重启&#xff0c;还可以使用如下两种方式处理。 方式1&#xff1a;ctrlaltFn 使用 ctrl alt F3~F6: 切换到其他 tty 命令行。 执行 top 命令查看资源占用最多的进程&#xff0c;然后使用 kill…

HEX报文协议打包生成工具

本工具可以用于灵活定制各种格式的报文。以下是定制报文中每个字段的说明&#xff1a; isbig&#xff1a;指示报文中的字节顺序是否为大端序&#xff08;Big Endian&#xff09;。如果为true&#xff0c;则表示使用大端序&#xff1b;如果为false&#xff0c;则表示使用小端序…

centrifuge5.0.1版本请求websocket实例

目录 一、安转 二、快速开始 三、实例开始 centrifuge提供了一个客户端&#xff0c;可使用纯 WebSocket 或一种替代传输&#xff08;HTTP 流、SSE/EventSource、实验性 WebTransport&#xff09;从 Web 浏览器、ReactNative 或 NodeJS 环境连接到Centrifugo或任何基于 Cent…

WorkPlus局域网即时通讯软件的领航者,连接高效协作的利器

在快速发展的商业环境中&#xff0c;高效的内部沟通和协作对于企业的成功至关重要。而局域网即时通讯软件则成为实现内部高效沟通的必备工具。作为一款领航者级别的局域网即时通讯软件&#xff0c;WorkPlus通过卓越的性能和创新的技术&#xff0c;成为了众多企业的首选之一。 W…

ggplot2 | line plot 分组及均值线:聚类后的表达变化趋势图

1. 效果图 2. 预处理及绘图 # 输入数据 > head(dat)Species cid variable value 1 setosa 1 Sepal.Length 5.1 2 setosa 2 Sepal.Length 4.9 3 setosa 3 Sepal.Length 4.7 4 setosa 4 Sepal.Length 4.6 5 setosa 5 Sepal.Length 5.0 6 setos…

selenium模块有哪些用途?

Selenium模块是一个用于Web应用程序测试的模块&#xff0c;具有多种示例用法。以下是一些示例&#xff1a; 1.打开网页并执行一些基本操作&#xff0c;如点击按钮、输入文本等。 定位网页元素并执行操作&#xff0c;例如使用 find_element 方法查找单个元素&#xff0c;使用 f…

2023第三届中国高校大数据挑战赛B题代码

任务已完成&#xff0c;聚类效果很好&#xff08;主要在于数据的处理以及特征工程&#xff09;, 需代码si&#xff0c;yuer有限先到先得。

Git 使用规范:起名字、提交描述的最佳实践

1. 推荐写法&#xff08;本人常用&#xff09; Git 仓库命令规则&#xff1a; 前端&#xff1a;系统名-简单描述-front后端&#xff1a;系统名-简单描述-server Git 提交描述&#xff1a; docs(changelog): update change log to beta.5其中&#xff1a; ● docs 则对应修改…

深度学习 | 基本循环神经网络

1、序列建模 1.1、序列数据 序列数据 —— 时间 不同时间上收集到的数据&#xff0c;描述现象随时间变化的情况。 序列数据 —— 文本 由一串有序的文本组成的序列&#xff0c;需要进行分词。 序列数据 —— 图像 有序图像组成的序列&#xff0c;后一帧图像可能会受前一帧的影响…

Linux 服务器安全策略技巧:使用容器进行应用程序隔离

Linux 服务器安全策略技巧:使用容器进行应用程序隔离 什么是容器? 容器是一种虚拟化技术,用于隔离应用程序和其依赖的运行环境。与传统的虚拟机相比,容器更加轻量级,启动速度更快,并且可以在不同的操作系统上运行。容器使用操作系统级别的虚拟化来实现隔离,每个容器都…

09.kubernetes 部署calico / flannel网络插件

脚本中实现了 calico 和 flannel 这两种主流的网络插件,选择其中一种部署即可 1、calico calico架构 Calico是一个三层的虚拟网络解决方案,它把每个节点都当作虚拟路由器(vRouter),并把每个节点上的Pod都当作是节点路由器后的一个终端设备并为其分配一个IP地址。各节点…

TCP/IP的五层网络模型

目录 封装&#xff08;打包快递&#xff09; 6.1应用层 6.2传输层 6.3网络层 6.4数据链路层 6.5物理层 分用&#xff08;拆快递&#xff09; 6.5物理层 6.4数据链路层 6.3网络层 6.2传输层 6.1应用层 封装&#xff08;打包快递&#xff09; 6.1应用层 此时做的数据…

Xshell——Windows将本地文件上传到Linux服务器

1、scp命令 scp是基于ssh的网络文件传输命令&#xff0c;可以将本地文件或文件夹直接上传到服务器指定位置。命令格式&#xff1a; 上传文件 scp -P port filepath usernameip:TargetPath 上传文件夹 scp -r -P port filepath usernameip:TargetPath -P port&#xff1a;用于指…