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.hqwc.cn/news/309451.html

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

相关文章

从0开始界面设计师 Qt Designer

QT程序界面的 一个个窗口、控件&#xff0c;就是像上面那样用相应的代码创建出来的。 但是&#xff0c;把你的脑海里的界面&#xff0c;用代码直接写出来&#xff0c;是有些困难的。 很多时候&#xff0c;运行时呈现的样子&#xff0c;不是我们要的。我们经常还要修改代码调整界…

【java爬虫】获取个股详细数据并用echarts展示

前言 前面一篇文章介绍了获取个股数据的方法&#xff0c;本文将会对获取的接口进行一些优化&#xff0c;并且添加查询数据的接口&#xff0c;并且基于后端返回数据编写一个前端页面对数据进行展示。 具体的获取个股数据的接口可以看上一篇文章 【java爬虫】基于springbootjd…

PAM的认证机制

PAM 首先要想了解什么是PAM机制&#xff0c;那么就要知道API API&#xff08;AWS PrivateLink&#xff09; 他可以使用户通过专用网络访问资源的技术。Apl接口是通过子啊vpc中创建节点来实现的。 PAM&#xff08;Pluggable Authentication Modules&#xff09; 是管理用户的…

【SD】tile 模型 - 固定衣服 生成人物 ☑

原理1&#xff1a;tile re 生成固定衣服的人物 tile1-1 re1-1 原理2&#xff1a;tile re 生成随机衣服的人物 tile0.5-1 re0.5-1 原理3&#xff1a;更改动作 必须使用衣服LORA 才可以进行穿衣服 测试大模型&#xff1a;###最爱的模型\meinamix_meinaV11.safe…

程序的编译、链接

目录 前言&#xff1a; 前置知识回顾 宏 宏定义常量 宏定义语句 宏定义函数 条件编译 应用场景 编译过程概览 预编译阶段 编译阶段 汇编阶段 链接阶段 前言&#xff1a; 在ANSI C的任何一种实现中&#xff0c;存在两种不同的环境&#xff0c;第1种是翻译环境&#x…

软件工程导论——(为什么要学习软件工程?软件工程能学到什么?如何学习软件工程?)

导论&#xff08;引言&#xff09;&#xff1a; 1.为什么要学习软件工程&#xff1f; 软件工程知识并不只是项目管理可以用&#xff0c;同样适用于开发岗。比如开发也要做需求分析和架构设计&#xff0c;也要做计划。学习软件工程后也可以帮助开发人员更好的理解软件项目的整个…

pnpm : 无法加载文件 C:\Program Files\nodejs\pnpm.ps1,因为在此系统上禁止运行脚本。

一、问题描述 在VS Code中运行Terminal中运行pnpm install&#xff08;npm或yarn也类似&#xff09;报错&#xff1a; S D:\workspace\xxx\xxx> pnpm install pnpm : 无法加载文件 C:\Program Files\nodejs\pnpm.ps1&#xff0c;因为在此系统上禁止运行脚本。有关详细信息…

DES加密算法优缺点大揭秘:为何它逐渐被取代?

一、引言 DES&#xff08;Data Encryption Standard&#xff09;加密算法作为一种历史悠久的对称加密算法&#xff0c;自1972年由美国国家标准局&#xff08;NBS&#xff09;发布以来&#xff0c;广泛应用于各种数据安全场景。本文将从算法原理、优缺点及替代方案等方面&#…

eve环境虚拟机和电脑如何传送文件

一.桥接 &#xff08;实现电脑和虚拟机在同一网段&#xff09; 虚拟机上网盘设置 二.属性---文件共享设置 1打开属性&#xff0c;点击共享 2.添加共享人为全部人&#xff0c;并修改权限为读写模式 3.点击高级共享&#xff0c;选定此文件夹 4.点击网络和共享中心&#xff0c;划…

Mixtral 8*7B + Excel + Python 超强组合玩转数据分析

Mixtral 8*7B Excel Python 超强组合玩转数据分析 0. 背景1. 使用 Mixtral 8*7B pandas 实现数据导入和导出1.1 使用 Mixtral 8*7B pandas 导入 Excel 文件中的数据1.2 使用 Mixtral 8*7B pandas 导出 Excel 文件中的数据 2. 使用 Mixtral 8*7B pandas 实现单个文件数据的…

Nginx快速入门:nginx实现正向代理|反向代理和正向代理的区别(八)

0. 引言 我们之前讲解的一直是nginx的反向代理配置&#xff0c;关于正向代理的实现一直没有涉及&#xff0c;但在实际生产中正向代理也有非常广泛的应用场景&#xff0c;因此&#xff0c;今天我们将针对正向代理来深入学习。 1. 相关概念 1.1 什么是反向代理 所谓反向代理&…

如何恢复 iPhone 上永久删除的照片?

2007年&#xff0c;苹果公司推出了一款惊天动地的智能手机&#xff0c;也就是后来的iPhone。你会惊讶地发现&#xff0c;迄今为止&#xff0c;苹果公司已经售出了 7 亿部 iPhone 设备。根据最新一项调查数据&#xff0c;智能手机利润的 95% 都进了苹果公司的腰包。 如此受欢迎…