【MYSQL】分组之后获取每组最新的数据

2023-05-16

记录一次有点麻烦的sql

可以直接复制拿去测试,一开始我也百度来着,发现要么没法满足我的需求,要么就连看下去的欲望都没有

建表测试demo:

CREATE TABLE `p_test` (
  `id` varchar(32) NOT NULL COMMENT '主键ID',
  `project_code` varchar(32) DEFAULT NULL COMMENT '项目编号',
  `collect_month` varchar(10) DEFAULT NULL COMMENT '月份',
  `evaluation_cycle` varchar(10) DEFAULT NULL COMMENT '考核周期',
  `production_completion_ratio` varchar(10) DEFAULT NULL COMMENT '发电量完成比例',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci ROW_FORMAT=DYNAMIC COMMENT='发电量监测';

假数据

INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('01', '123', '2017-06', '1', '0.89');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('02', '123', '2017-08', '1', '0.90');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('03', '123', '2018-06', '2', '0.79');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('04', '123', '2018-09', '2', '0.86');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('05', '123', '2019-06', '3', '0.88');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('06', '123', '2019-07', '3', '0.95');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('07', '123', '2020-06', '4', '0.96');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('08', '123', '2020-09', '4', '0.94');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('09', '123', '2021-06', '5', '0.93');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('10', '123', '2021-07', '5', '0.99');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('11', '124', '2017-06', '1', '0.89');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('12', '124', '2017-08', '1', '0.90');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('13', '124', '2018-06', '2', '0.79');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('14', '124', '2018-09', '2', '0.86');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('15', '124', '2019-06', '3', '0.88');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('16', '124', '2019-07', '3', '0.95');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('17', '124', '2020-06', '4', '0.96');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('18', '124', '2020-09', '4', '0.94');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('19', '124', '2021-06', '5', '0.93');
INSERT INTO `p_test`(`id`, `project_code`, `collect_month`, `evaluation_cycle`, `production_completion_ratio`) VALUES ('20', '124', '2021-07', '5', '0.99');

如上表,考核周期基本为一年一个周期,一个周期也就是最多存在12个月,此表数据也就是说一个项目,在每个月在这张表里面只存在一条数据

需求:

需要展示一个列表,项目名,考核周期(1,2,3,4,5)。。。。。项目名下展示项目即可,考核周期下展示每个周期的发电完成比例,注意坑爹的地方来了,一个考核周期存在12个月,也就是12条数据,正常一个考核年的数据不应该求平均吗,非要展示当前考核年最后一个月的数据,尝试过好多次,分组之后数据就没法确定,是不是当前考核年的最后一个月数据

有人可能会说,那按照一年12个月算,加个条件月份等于12不就好啦,但是如果12月份这个项目没数据呢,那不就查不出来了,
有人可能会说,这还不简单,直接按照月份倒叙排列之后limit 1 不就好了,我也这么想过,但是limit这个关键字是最后执行的,加了就只会取出来一条数据,但是我需求全部项目的数据

这就很坑了,尝试好久

如图:表里总共20条数据,根据上面需求,我需要查出来箭头指向的十条数据
在这里插入图片描述
sql如下:记录起来


		SELECT
            m.*
        FROM
            (
                SELECT
                    project_code,
                    evaluation_cycle,
                    collect_month,
                    production_completion_ratio
                FROM
                    p_test
                WHERE
                    1 = 1
                GROUP BY
                    project_code,
                    evaluation_cycle,
                    collect_month
            ) m,
            (
                SELECT
                    project_code,
                    evaluation_cycle,
                    max(collect_month) collect_month
                FROM
                    p_test
                WHERE
                    1 = 1
                GROUP BY
                    project_code,
                    evaluation_cycle
            ) n
        WHERE m.project_code = n.project_code
          AND m.evaluation_cycle = n.evaluation_cycle
          AND m.collect_month = n.collect_month
          

执行结果:

在这里插入图片描述

结束语

网上没找到类似的解决方案,想了几个小时,暂时只想到这种笨方法解决

有没有大佬知道什么sql函数可以直接获取分组之后,根据某个字段获取这一条数据整条信息的,而不是分组之后获取某个字段的最大最小值之类的,欢迎大佬前来指教

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【MYSQL】分组之后获取每组最新的数据 的相关文章

  • 5.Linux系统中解压缩详解

    文章目录 前言1 打包 归档 和压缩2 tar命令详解 xff08 打包和解包 xff09 3 tar命令详解 xff08 解压缩 xff09 4 zip命令详解5 unzip命令6 gzip命令7 gunzip命令8 bzip29 bun
  • 3.Shell位置变量和参数用法详解,位置参数变量作用,$,#,*,$1,$2等详解和例子

    位置变量 参数用法详解 位置参数变量作用 1 2等详解和例子 文章目录 前言位置参数变量作用例子 64 示例 和 64 的区别 总结友情链接 前言 位置变量 xff1a 在bash shell中内置的变量 在脚本代码中调用通过命令行传递给脚
  • 代码手写UI,xib和StoryBoard间的博弈,以及Interface Builder的一些小技巧

    代码手写UI 这种方法经常被学院派的极客或者依赖多人合作的大型项目大规模使用 Geek们喜欢用代码构建UI xff0c 是因为代码是键盘敲出来的 xff0c 这样可以做到不开IB xff0c 手不离开键盘就完成工作 xff0c 可以专注于编
  • Python:if 语句的基本使用

    今天 xff0c 我们将学习Python中if语句的基本使用 if 在Python中用作某个条件或值的判断 xff0c 格式为 xff1a span class token keyword if span 条件 span class tok
  • Python模块介绍使用:zmail模块读取邮箱内邮件信息

    hello xff0c 大家好 xff0c 我是wangzirui32 xff0c 今天来教大家如何使用zmail模块读取邮箱内邮件信息 xff0c 开始学习吧 xff01 1 zmail安装 在命令行中输入以下命令即可安装 xff1a p
  • Python模块介绍使用:Python-Markdown解析Markdown文本

    博文作者 wangzirui32 x1f496 喜欢的可以 点赞 收藏 关注哦 x1f44f 我的第155篇原创作品 x1f449 本文首发于CSDN xff0c 未经许可禁止转载 x1f60e hello xff0c 大家好 xff0c
  • 【python学习】——字符串

    字符串 一 字符串的驻留机制 xff08 1 xff09 在python中它是基本数据类型 xff0c 是一个不可变的字符序列 xff08 2 xff09 字符串的驻留机制 xff1a 仅保存一份相同且不可变字符串的方法 xff0c 不用的
  • Linux安装部署SonarQube9.9 代码审查工具

    Linux安装部署SonarQube9 9 代码审查工具 1 SonarQube 简介 2 SonarQube安装与配置 2 1 官方软件包版本要求 2 2 基础环境配置 2 3 安装SonarQube 2 4 安装并配置PostgreSQ
  • 【数据库】Postgresql 与 MySQL 比较

    目录 Postgresql 与 MySQL 比较历史支持平台二者底层特性库存储引擎对数据的管理表连接算法 应用场景面向开发使用 Postgresql 与 MySQL 比较 二者都是比较强大的数据库 xff0c 选择使用哪一个数据库需要结合实
  • H5的离线缓存技术

    离线存储可以将站点的一些文件存储在本地 xff0c 它是浏览器自己的一种机制 xff0c 将需要的文件缓存下来 在没有网络的时候可以访问到缓存的对应的站点页面 xff0c 包括html xff0c js xff0c css xff0c im
  • QEMU虚拟机怎么配置网络才能主机和虚拟机都通

    当打开QEMU虚拟机配置界面的时候 xff0c 可以看到多种网络模型 而其中默认使用的是NAT xff0c 你会发现 xff0c 当你创建完虚拟机直接去配置网络之后 xff0c 网络是不通的 然后切换为其他模式之后 xff0c 你会发现 x
  • 虚拟机设置开机启动自动运行脚本

    首先设置虚拟机开机免密码自动启动 2 设置好开机免密码之后 xff0c 在配置开机自动启动脚本 编写一个bat文件作为脚本 xff0c 并将它放入到如下目录中 C ProgramData Microsoft Windows Start Me
  • QEMU虚拟机怎么配置网络

    当打开QEMU虚拟机配置界面的时候 xff0c 可以看到多种网络模型 而其中默认使用的是NAT xff0c 你会发现 xff0c 当你创建完虚拟机直接去配置网络之后 xff0c 网络是不通的 然后切换为其他模式之后 xff0c 你会发现 x
  • 关于VMware上的VAAI特性详解

    一般来说我们的存储在适配VMware的时候 xff0c 会牵涉搭配VAAI特性 xff0c 经常听到VAAI这到底是什么呢 xff1f VAAI的全称是VMware s Storage APIs for Array Integration
  • Python2.7版本安装报错

    python E S m sysconfig generate posix vars Could not find platform dependent libraries lt exec prefix gt Consider settin
  • oracle的安装(Oracle11G release2)

    一 xff1a 准备工作 1 关闭selinux 永久关闭 设置SELINUX 61 disabled xff1a vim etc selinux config 2 关闭firewalld 安装iptables systemctl stop
  • openstack kilo单击版本安装-最简单的安装方式

    由于K版本已经比较老了 xff0c 甚至连源都已经不怎么找得到了 xff0c 但是有时候为了一些特定的需求 xff0c 需要安装K版本 xff0c 这就比较麻烦 xff0c 本文找了一个较为简单的方法来安装 xff0c 并且是单机安装 准备
  • 本地显示远程服务器图形界面

    解决方案 序号方案简单区别方案一Xmanager1 VNC连接时及时突然中断 xff08 比如断网 xff09 xff0c 不影响操作进行 xff1b 2 不需要在服务器上装软件 xff0c 需要在你的电脑上装相应软件 xff0c 使用SS
  • SQL解析json(包含单层解析、多层解析)解析的数据可直接存到表中

    单层json解析 声明变量 declare 64 JsonData nvarchar max 61 39 34 BillName 34 34 12345765 34 34 SendDate 34 34 2022 11 10T00 00 00
  • MySQL查看当前使用的配置文件my.cnf的方法

    MySQL查看当前使用的配置文件my cnf的方法 MySQL实例在启动时 xff0c 会先读取配置参数文件my cnf my cnf一般会放在MySQL的安装目录中 xff0c 用户也可以放在其他目录加载 安装MySQL后 xff0c 系

随机推荐

  • Latex 之 微分符号d的竖立表达 {\rm d}

    微分符号d竖立表达 rm d
  • Abaqus 导出XYdata的几种方式

    目录 方法一 xff1a 通过Plu ins gt Tools gt Excel Utilities xff0c 将XY Data直接到Excel文件里 xff01 方式二 xff1a Report gt XY xff0c 导出默认 rpt
  • ABAQUS 显示应力/应变场的最大/最小值

    如下图所示 xff0c 可以显示最大最小值 具体数据导出 xff1a Report gt Field Output 导出结果 场输出 xff08 Field output xff09 同一时刻 xff0c 不同位置 xff1b 历史输出 H
  • mac下重装系统,应用程序副本已损坏 的解决办法

    首先需要确定电脑的年份和对应的系统 xff0c 简单的道理是老的电脑硬件是不适配最新系统的 xff0c 我需要安装的是10 12的系统 系统来源 xff1a 黑苹果 年份确定 xff1a 2017年9月之前生产的电脑 我用的是U盘安装的方法
  • mysql查看数据库的容量及表容量

    select table schema sum DATA LENGTH 43 sum INDEX LENGTH from information schema tables group by table schema 在需要备份数据库里面的
  • 【数据结构-栈】借助栈实现回文的判断

    数据结构 栈 借助栈实现回文的判断 最近在学习栈 xff0c 尝试用C实现了一些功能 include lt stdio h gt include lt stdlib h gt typedef struct app char date str
  • C语言实现冒泡排序

    冒泡排序作为学习排序最基本的算法 xff0c 具有稳定性与实用性 下面是C语言冒泡排序的源代码 include lt stdio h gt int main void int a 10 61 6 4 3 2 7 8 9 10 1 5 int
  • C语言实现快速排序算法

    快排作为公认最优秀的排序方法 xff0c 是每一个程序员都应该掌握的 xff0c 那么 xff0c 今天就由我来为大家简单讲解一下快速排序算法的代码 源代码如下 xff1a include lt stdio h gt void quicks
  • C语言实现二分查找

    相较于线性查找 xff0c 二分查找在面对大量数据时的效率更高 xff0c 但它的缺点是只能对有序数组进行查找 源代码如下 xff1a include lt stdio h gt void binarysearch int a int su
  • 约瑟夫环详解

    package newjosephu public class myfinaljosephu 你可能会说crazy 我只想说ez xff01 public static void main String args circlelinkedl
  • ECS弹性云服务器常用端口、安全组

    弹性云服务器常用端口 弹性云服务器常用端口如 表1 所示 您可以通过配置安全组规则放通弹性云服务器对应的端口 xff0c 详情请参见 添加安全组规则 表1 弹性云服务器常用端口 协议 端口 说明 FTP 21 FTP服务上传和下载文件 SS
  • 01背包问题(滚动数组实现的逻辑)

    package tttest public class mybetterbag public static void main String args int weight 61 1 3 4 int bagsize 61 4 int val
  • java递归实现辗转相除法

    public static int getres int a int b if b 61 0 return getres b a b return a
  • java 线索二叉树的构建

    public class test public static void main String args Node root 61 new Node 1 Node node2 61 new Node 2 Node node3 61 new
  • ubuntu下查看文件(夹)大小的命令

    记录下自己常用的查看文件夹和文件大小的命令 查看当前所处的文件夹的整个大小 xff08 不包括具体内容 xff0c 只看当前文件夹大小 xff09 span class token function du span sh 查看当前文件夹中各
  • git stash时出现xxx:needs merge问题

    项目需要git merge其他分支 xff0c 但由于本地也修改过 xff0c 所以希望先git stash后再merge xff0c 这时出现以下问题 xff1a xxx xxx xxx cpp xff1a needs merge 通过g
  • FFMPEG 之视频播放

    先看界面效果 xff0c 虽然有点low xff0c 但是效果实现了 一 实现原理 1 使用ffmpeg解码视频 2 然后使用libyuv播放解码的视频 二 实现 1 先看目录结构 2 ffmpeg编译以及引用 xff0c 在之前的篇章已经
  • 一步一步学CMake 之 VSCode+CMakeLists 调试 C++ 工程

    目录 1 插件推荐 2 文件准备 3 开始调试 一步一步学 CMake 系列文章 1 插件推荐 CMake CMake tools 2 文件准备 新建文件夹 xff1a TEST 新建文件 xff1a CMakeLists txt 内容如下
  • 51单片机使用8位重装定时器实现PWM输出同时实现DAC转换

    51单片机使用八位重装定时器实现PWM输出同时实现DAC转换 最近想要做一个数控电源 xff0c 打算使用51单片机实现电压和电流的闭环 xff0c 但是手头上的51单片机为STC89C51系列的单片机 xff0c 没有ADC采样功能 xf
  • 【MYSQL】分组之后获取每组最新的数据

    记录一次有点麻烦的sql 可以直接复制拿去测试 xff0c 一开始我也百度来着 xff0c 发现要么没法满足我的需求 xff0c 要么就连看下去的欲望都没有 建表测试demo xff1a span class token keyword C