mysql简单数据查询——数采数据电量与耗料的日统计

news2025/1/15 17:35:58

目录

前言

步骤1:date_format函数

步骤2:concat函数

步骤3、4:查询中使用变量

完整代码


前言

在数采数据已写入mysql数据库中后,进行数据处理,统计电量与耗料数据

由于数据库版本较低,无法使用较新的函数

需要做的操作:

1、查询增加列:采集日期(去除具体的时分秒)

2、查询增加列:合并不同信息(产线名称、数采点位、采集日期)

3、查询增加列:前一行数据

4、得到结果集:产线名称、数采点位、单位、采集日期、开始采集时间、结束采集时间、累计数据

基础数据:1号线、2号线、14号线为产线名称;总耗料、总电量为采集数据;总耗料和总电量是会递增的,在HMI可以进行清零操作,在超过PLC该点位最大值后,也会进行清零

源数据T1:

步骤1:date_format函数

MySQL DATE_FORMAT() 函数

DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据

语法:DATE_FORMAT(date,format)

date 参数是合法的日期。format 规定日期/时间的输出格式

%Y   年,4 位

%m  月,数值(00-12)

%d   天,数值(00-31)

用 DATE_FORMAT() 函数来显示不同的格式。使用NOW()来获得当前的日期/时间:

DATE_FORMAT(NOW(),'%m-%d-%Y');

select DATE_FORMAT(NOW(),'%Y-%m-%d') now_date from dual;

步骤2:concat函数

MySQL concat () 函数

将多个字符串连接成一个字符串

concat(str1, str2,...) 返回结果为连接参数产生的字符串,如果该函数中的任何参数为NULL,返回结果为NULL

select concat("abc","123") str from dual;

步骤3、4:查询中使用变量

当前行数据减去上一行数据:

1、定义A.V初始值为0

2、将A表查出来,将变量@A.V复制给V2,将当前值V赋值给变量@A.V

3、将V-V2

(第一行没有上一行,所以减去后的结果还是第一行的数据)

源数据

SELECT T.I,T.V,V-V2 DIFF
FROM(
SELECT A.I AS I, A.V AS V, @A.V AS V2, @A.V:= A.V
FROM
(select 11 V, 1 I from dual
union ALL
select 93 V, 2 I from dual
union ALL
select 41 V, 3 I from dual
union ALL
select 55 V, 4 I from dual
union ALL
select 17 V, 5 I from dual) A,(SELECT @A.V:=0)B
)T

完整代码

-- 步骤4
SELECT
	T5.device_name,  #产线名称
	T5.sen_name,    #数采点位
	T5.sen_unit,      #单位
	T5.collect_date,   #采集日期
	min( T5.collect_time ) start_collect,#开始采集时间
	max( T5.collect_time ) end_collect,#结束采集时间
	round(sum(IF((T5.sen_data < T5.data_last 
			AND T5.device_name = T5.dev_last 
			AND T5.sen_name = T5.sen_last),T5.sen_data,(T5.sen_data - T5.data_last))),3) sum_data #累计数据
-- 防止清零影响数据准确性 若上一个数据大于本条数据,名称相同,点位相同,可能是因为清零的原因
FROM(
-- 步骤3
	SELECT
		T4.*,
		@T4.sen_data AS data_last,   -- 前一行数据
		@T4.sen_data := T4.sen_data,
		@T4.device_name AS dev_last, -- 前一行设备
		@T4.device_name := T4.device_name,
		@T4.sen_name AS sen_last,   -- 前一行产线
		@T4.sen_name := T4.sen_name 
	FROM
		(
        -- 步骤2
SELECT
			T1.*,
			concat( T1.device_name, T1.sen_name, T1.collect_date ) Conbine 
		  FROM(
            -- 步骤1
			SELECT T1.*,
				   date_format( T1.collect_time, '%Y-%m-%d' ) collect_date #采集日期
			 FROM T1
			) T1 
		ORDER BY
			concat( T1.device_name, T1.sen_name, T1.collect_date ) ASC,
			T1.collect_time ASC 
		) T4,
		(SELECT @T4.sen_data := 0.000, @T4.device_name := NULL, @T4.sen_name := NULL ) tmp 
	) T5 
WHERE
	T5.device_name = T5.dev_last 
	AND T5.sen_name = T5.sen_last 
GROUP BY
	T5.device_name,#设备名称
	T5.sen_name,  #传感器名称
	T5.sen_unit,    #传感器单位
	T5.collect_date; #数据采集日期

得到结果:

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

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

相关文章

华为策略路由实验配置

配置接口相关的IP地址&#xff0c;并配置IGP路由协议使得全网互通 AR1配置接口策略路由 对经过本地转发的路由生效&#xff0c;对本地始发的路由不生效 配置nqa检测下一跳状态 nqa test-instance PC1 icmptrace nqa的管理者为PC1&#xff0c;NQA的测试例名为icmptrace test-…

全国青少年软件编程(Scratch)等级考试二级考试真题2022年12月——持续更新.....

1.一个骰子,从3个不同角度看过去的点数如图所示,请问5的对面是什么点数?( ) A.1 B.3 C.4 D.6 正确答案:A 答案解析: 根据图三,用右手定则,大拇指朝上指向6所对的方向,其余四指握起来表示旋转方向,可以看到先5后2,然后把这个姿势对应到图1中,就知道1的对面是5…

C语言进阶(8)——动态内存空间管理

前言 文章目录前言1.为什么存在动态内存分配2.动态内存函数的介绍2.1 malloc函数2.2 free函数2.3 calloc2.4realloc3 常见的动态内存错误4.经典笔试题题目 1&#xff1a;题目 2&#xff1a;题目 3&#xff1a;题目 4&#xff1a;5.C/C程序的内存开辟6.柔性数组6.1 定义6.2 柔性…

1.5、中断和异常

整体框架 1、中断的概念和作用 当中断发生时&#xff0c;CPU 立即进入核心态\color{red}核心态核心态 当中断发生后&#xff0c;当前运行的进程暂停运行&#xff0c;并由操作系统内核对中断进行处理 对于不同的中断信号&#xff0c;会进行不同的处理 发生了中断&#xff0c…

记录--“非主流” 的纯前端性能优化

这里给大家分享我在网上总结出来的一些知识&#xff0c;希望对大家有所帮助 性能优化一直是前端研究的主要课题之一&#xff0c;因为不仅直接影响用户体验&#xff0c;对于商业性公司&#xff0c;网页性能的优劣更关乎流量变现效率的高低。例如 DoubleClick by Google 发现&…

MD5加密

MD5加密 md5加密 明文 加密变成 128位二进制 --> 32位16进制字符串的密文 MD5特征: 明文一样, 得到密文一样密文一样, 推出明文一样明文不一样, 得到密文不一样 缺点&#xff1a; 现在网上有很多暴力破解的网址&#xff0c;直接使用md5加密还是不太安全 为了提高安全性&am…

Linux常用命令——vmstat命令

在线Linux命令查询工具(http://www.lzltool.com/LinuxCommand) vmstat 显示虚拟内存状态 补充说明 vmstat命令的含义为显示虚拟内存状态&#xff08;“Viryual Memor Statics”&#xff09;&#xff0c;但是它可以报告关于进程、内存、I/O等系统整体运行状态。 语法 vmst…

Java高并发编程实战,异步注解@Async自定义线程池

一、Async注解 Async的作用就是异步处理任务。 在方法上添加Async&#xff0c;表示此方法是异步方法&#xff1b; 在类上添加Async&#xff0c;表示类中的所有方法都是异步方法&#xff1b; 使用此注解的类&#xff0c;必须是Spring管理的类&#xff1b; 需要在启动类或配置类…

ELK日志(1)

Elasticsearch开源分布式搜索引擎&#xff0c;它的特点有&#xff1a;分布式&#xff0c;零配置&#xff0c;自动发现&#xff0c;索引自动分片&#xff0c;索引副本机制&#xff0c;restful 风格接口&#xff0c;多数据源&#xff0c;自动搜索负载等。RESTFUL特点包括&#xf…

MES系统之工控

MES系统之工控 要控制MES系统首先要对他有个了解。MES系统最早由1990年&#xff0c;由美国先进制造研究中心AMR提出的&#xff0c;当时中文意思叫制造执行系统概念。直到1997年&#xff0c;MESA(制造执行系统协会)提出了MES功能组件和继承模型&#xff0c;到20世纪90年代初期&a…

动态内存管”家“

&#x1f40b;动态内存管理&#x1f996;动态内存分配存在的意义&#x1f996;动态内存函数的介绍&#x1f424;malloc和free&#x1f424;calloc&#x1f424;realloc&#x1f996;常见动态内存错误&#x1f424;对空指针的解引用操作&#x1f424;对动态开辟空间的越界访问&a…

springMVC的响应

SpringMVC接收到请求和数据后&#xff0c;进行一些了的处理&#xff0c;当然这个处理可以是转发给Service&#xff0c;Service层再调用Dao层完成的&#xff0c;不管怎样&#xff0c;处理完以后&#xff0c;都需要将结果告知给用户。 对于响应&#xff0c;主要就包含两部分内容&…

关于 sensor hdr 模式下不出图/出图异常的排查方法

1、问题背景&#xff1a;有项目调试过 ov02k10&#xff08;1920*1080&#xff09;和 sc301IoT&#xff08;2048*1536&#xff09;两款 sensor, 都有出现 hdr 模式下出图异常或者不出图的问题&#xff0c;总结下排查过程及注意事项&#xff1b;2、问题现象&#xff1a;a、ov02k1…

Odoo 16 企业版手册 - 库存管理之寄售

寄售 使用“「设置」”菜单下提供的「寄售」选项&#xff0c;可以对库存中储存的产品设置所有者。产品将由零售商销售&#xff0c;但产品的实际所有权将由供应商持有&#xff0c;直到产品出售给客户。通过这种方法&#xff0c;您可以轻松地将未售出的产品退还给供应商。在寄售的…

java对接阿里云短信服务详解(验证码,推广短信,通知短信)

前言 小前提&#xff1a; - java&#xff1a;springboot框架&#xff0c;maven版本管理。 - 阿里云&#xff1a;有账号&#xff0c;已经进行实名认证。 java对接阿里云短信服务详解&#xff08;验证码&#xff0c;推广短信&#xff0c;通知短信&#xff09;前言1. 登录阿里云进…

基于servlet+mysql+jsp实现体育用品商城

基于servletmysqljsp实现体育用品商城一、系统介绍1、系统主要功能&#xff1a;2、环境配置二、功能展示1.主页(客户)2.登陆&#xff08;管理员&#xff09;3.主页&#xff08;管理员&#xff09;4.订单管理&#xff08;管理员&#xff09;5.客户管理&#xff08;管理员&#x…

linux系统结构

目录 0.前言 1.系统结构图 1.1.操作系统工作方式 1.2.高版本和低版本内核区别 0.前言 本专栏&#xff0c;是记录内核学习的&#xff0c;参考b站linux内核源码分析&#xff0c;以及linux内核艺术图解。后面的文章将记录个人的学习&#xff0c;源码注释&#xff0c;源码理解…

ANSYS Products 2020 R1 Linux64版本安装

fluent系列 占位 fluent2020R1版本安装fluent系列前言一、基础环境二、安装准备1.图形化环境准备2.路径准备3.挂载安装用iso4.拷贝安装文件三、开始安装1.进入图形化界面2.开始安装3.试运行fluent四、替换破解版的license总结前言 在centos7环境下安装使用fluent的部署记录。…

不用if else if 如何 解决文末尾问题

根据条件判断发送axios所携带的参数&#xff0c;这是搜索的2个条件&#xff0c;如果为空就按照空这个条件来搜索&#xff0c;所以为空携带参数就不能有他&#xff0c;导致if else if 的连续判断 开始来没有思路&#xff0c;随便尝试尝试&#xff0c;来打开自己的思路 期间尝…

【学习经验分享NO.20】代码报错(可帮助远程调试代码)

本博客会整理分享一些报错问题以及解决办法&#xff0c;本文会不断进行更新。有需求的朋友可以关注私信我&#x1f618;进行远程调试。&#x1f349;1.报错1问题nn.functional.sigmoid is deprecated. Use torch.sigmoid instead.解决办法将项目中的F.sigmoid修改为torch.sigmo…