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

news2025/1/19 14:13:20

文章目录

  • 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.coloradmin.cn/o/1344914.html

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

相关文章

城市生态数据大屏,PSD设计稿

现分享生态系统可视化大数据大屏的 Photoshop 源文件&#xff0c;下载即用&#xff01;以下为截图示意。 若需 更多行业 相关的大屏&#xff0c;请移步小7的另一篇文章&#xff1a;200套精选数据可视化大屏&#xff0c;大屏PSD设计&#xff08;各行业大屏UI&#xff09;https:…

Pandas教程(一)—— 数据结构

前言 Pandas是贯穿数据分析的主要工具之一&#xff0c;它经常和其他数值计算工具一起使用&#xff08;例如&#xff1a;Numpy、SciPy和matplotlib&#xff09;。尽管pandas采用了很多NumPy的代码风格&#xff0c;但二者最大的区别是&#xff1a;pandas主要用于处理表格型或异质…

机器学习系列11:减少过拟合——L1、L2正则化

如果我们注意到模型在训练集上的表现明显优于模型在测试集上的表现&#xff0c;那么这就是模型过拟合了&#xff0c;也称为 high variance。 产生的过拟合的原因是对于给定的训练集数据来说&#xff0c;模型太复杂了。有几种可以减少过拟合的方法&#xff1a; 收集更多的训练数…

洛谷 P1086:花生采摘 ← 结构体

【题目来源】https://www.luogu.com.cn/problem/P1086https://www.acwing.com/problem/content/description/420/【题目描述】 在告示牌背后&#xff0c;路边真的有一块花生田&#xff0c;花生植株整齐地排列成矩形网格&#xff08;如图 1&#xff09;。 有经验的多多一眼就能看…

Net6 Core webApi发布到IIS

Net6 Core Api发布到IIS不同于webapi&#xff0c;依赖框架不同&#xff0c;配置也移至项目内Program.cs 一、发布到指定文件夹和IIS&#xff0c;不过注意IIS应用程序池选择的是 “无托管代码“ 在IIS管理器中点击浏览&#xff0c;访问接口路径报500.19&#xff0c;原因是所依赖…

Prometheus告警处理

Alertmanager介绍 Prometheus 包含一个报警模块&#xff0c;就是 AlertManager&#xff0c;Alertmanager 主要用于接收 Prometheus 发送的告警信息&#xff0c;它支持丰富的告警通知渠道&#xff0c;而且很容易做到告警信息进行去重、降噪、分组等&#xff0c;是一款前卫的告警…

链表精选题集

目录 1 链表翻转 题目链接&#xff1a; 解题&#xff1a; 试错版&#xff1a; 2 找中间节点 题目链接: 题解&#xff1a; 3 找倒数第k个节点 题目链接&#xff1a; 题解&#xff1a; 4 将两个升序链表合并为一个升序链表 题目链接&#xff1a; 题解&#xff1a; …

[电磁学]猴博士不挂科

1 利用表格求场强 2 利用叠加求场强 3 利用积分求场强 电场立库仑力 球的面积公式是4πr&#xff0c;其中r为球的半径。 球的体积公式是(4/3)πr&#xff0c;其中r为球的半径。 带电物体有体积:

软件测试/测试开发丨Python 内置库 OS 学习笔记分享

os 概述 os: Operating System os 使用 导入 os 模块 查看 os 模块使用文档 help(os)dir(os) import os# 查看os模块说明文档 help(os)# 查看os模块的属性和方法 print(dir(os))os 操作系统相关 os.name&#xff1a;获取系统名称os.environ&#xff1a;获取系统环境变量信…

是时候将javax替换为Jakarta了

开始 相信很多朋友在使用新版本的Spring的时候&#xff0c;发现了一些叫jakarta的包&#xff0c;看起来有点陌生。 很多时候&#xff0c;比较纠结不知道该导入哪一个包。 jakarta其实就是之前的javax。 主要JavaEE相关的&#xff0c;从之前javax名字也可以看出来&#xff0…

【AMD Xilinx】ZUBoard(2):通过AXI GPIO控制PL端的管脚输出

【AMD Xilinx】ZUBoard&#xff08;2&#xff09;&#xff1a;通过AXI GPIO控制PL端的管脚输出 一、基本功能和流程二、Vivado工程1. 总体框图2. AXI GPIO相关部分3. 配置AXI GPIO4. 绑定管脚4.1 根据原理图查找对应管脚4.1.1 LED04.1.2 LED1 4.2 I/O Planning 5. XDC 三、ARM代…

python+django游戏分享论坛网站49c2c

本系统主要包括管理员和用户两个角色组成&#xff1b;主要包括首页、个人中心、用户管理、游戏类型管理、游戏文章管理、交流论坛、系统管理等功能的管理系统。 系统权限按管理员和用户两类涉及用户划分。 &#xff08;1&#xff09;管理员功能需求 管理员登陆后&#xff0c;主…

c++学习笔记-提高篇-STL-函数对象

目录 一、函数对象 二、函数对象使用 三、谓词 1、概念 2、一元谓词 3、二元谓词 插入一条sort函数源码 四、内建函数对象 1.基本概念 2、算数仿函数 3、关系仿函数 4、逻辑仿函数 一、函数对象 函数对象概念 &#xff08;1&#xff09;重载函数调用操作符的类&a…

ESP32:整合存储配网信息和MQTT笔记

文章目录 1.给LED和KEY的所用IO增加配置项1.1 增加配置文件1.2 修改相应的c源码 2. 把mqtt\tcp的工程整合到一起2.1 在何处调用 mqtt_app_start() 3. 测试MQTT4. 完整的工程源码 有一段时间没有玩ESP32&#xff0c;很多知识点都忘记了。今天测试一下MQTT&#xff0c;做个笔记。…

Vue.js学习笔记(1)——Visual Studio Code搭建Vue.js框架

1 安装Node.js 1、下载安装包&#xff1a;进入官网&#xff08;https://nodejs.org/en&#xff09;&#xff0c;下载左侧的稳定版。 2、选择安装位置&#xff0c;不用勾选自动安装必要工具。 其他都默认Next。 配置环境&#xff0c;具体参考本文章&#xff1a; https://blo…

数据结构之树 --- 二叉树 < 堆 >

目录 1. 树是什么&#xff1f; 1.1 树的表示 2. 二叉树 2.1 二叉树的概念 2.2 特殊的二叉树 2.3 二叉树的性质 2.4 二叉树的存储结构 2.4.1 顺序存储 2.4.2 链式存储 3. 二叉树顺序结构的实现 <堆> 3.1 二叉树的顺序结构 ​编辑 3.2 堆的概念及结构 ​编辑…

啊?这也算事务?!

作者简介&#xff1a;大家好&#xff0c;我是smart哥&#xff0c;前中兴通讯、美团架构师&#xff0c;现某互联网公司CTO 联系qq&#xff1a;184480602&#xff0c;加我进群&#xff0c;大家一起学习&#xff0c;一起进步&#xff0c;一起对抗互联网寒冬 学习必须往深处挖&…

数据库开发之事务和索引的详细解析

2. 事务 场景&#xff1a;学工部整个部门解散了&#xff0c;该部门及部门下的员工都需要删除了。 操作&#xff1a; -- 删除学工部 delete from dept where id 1; -- 删除成功 ​ -- 删除学工部的员工 delete from emp where dept_id 1; -- 删除失败&#xff08;操作过程中…

Linux升级指南:保持系统安全和高效运行

Linux系统的升级是确保系统稳定和安全性的重要步骤。本文将介绍Linux系统升级的基本概念&#xff0c;以及具体的操作步骤和注意事项&#xff0c;以帮助用户顺利升级他们的Linux系统。 Linux操作系统以其稳定性和可定制性而闻名&#xff0c;它经常通过升级来提供新的功能、修复漏…

C++ 之LeetCode刷题记录(五)

&#x1f604;&#x1f60a;&#x1f606;&#x1f603;&#x1f604;&#x1f60a;&#x1f606;&#x1f603; 开始cpp刷题之旅&#xff0c;多学多练&#xff0c;尽力而为。 先易后难&#xff0c;先刷简单的。 20. 有效的括号 给定一个只包括 ‘(’&#xff0c;‘)’&…