SQL分组取最大值的方法

article/2025/10/17 6:02:40

一、业务需求

1.1.数据表展示

1.2.查询要求

        要求查询所有字段,并按iceName,orderPath,exceptionType分组,在分组时取systemTime值最大的那条数据

        注:本文适用于查询多字段的查询,单纯的 select MAX(字段A)  或select  B,MAX(字段A) 这种字段单一的sql,本文不做介绍。

二、查询思路

首先使用简单语句进行查询。

SELECT id,iceName,createDate,createTime,orderPath,exceptionType,orderId,
emailStatus,MAX(systemTime)
FROM orderAlarms WHERE emailStatus='1' 
GROUP BY iceName,orderPath,exceptionType;

当MAX函数位于where之后,会报错,因此只能尝试将MAX函数放在where之前,如上所示

由于表数据较多,在此截图并不能完整体现下述错误,因此不做展示。

但这种情况会出现错误数据:MAX函数取值正确,但select之后的其他数据,与MAX函数中的数据,并不是同一条数据。头是头,尾是尾,头尾拼接却不是一个整体。原因是select查询是把后面的字段拼接成一条SQL的,这种会造成数据错误,因此MAX函数并不能放在 where之前。

在使用简单语句,但不能满足需求时,那就使用复合语句进行查询。

SELECT id,iceName,createDate,createTime,orderPath,exceptionType,
orderId,emailStatus,systemTime
FROM orderAlarms WHERE emailStatus='1' AND systemTime=(SELECT MAX(systemTime))
GROUP BY iceName,orderPath,exceptionType;

此时查询到的数据,部分复合查询要求。但由第一张图可知,id 3、4和5都是同一组数据,根据systemTime比较可知,此时应该取的是id为5的数据,因此查询到的id为3的数据显然是不正确的。

《受数据库配置影响,部分数据库并不能运行上述sql,解决办法戳》 

重新阅读查询条件,“ ******在分组时取systemTime值最大的那条数据 ”,因此MAX(systemTime)应该被当做查询条件,也就是需要先把MAX(systemTime)查出来,然后再查询。

但仅仅使用MAX(systemTime)函数是不能满足要求的,因为这查出来是1条数据。所以需要将分组函数和MAX(systemTime)搭配起来使用,先把符合条件的MAX(systemTime)查出来

SELECT MAX(systemTime) FROM orderAlarms 
WHERE emailStatus='1'
GROUP BY iceName,orderPath,exceptionType

这个时候是有多条数据的,当多条数据作为查询条件时,= 已经不再适用,因此需要搭配 in 来进行查询,组合起来就是

SELECT id,iceName,createDate,createTime,orderPath,exceptionType,orderId,
emailStatus,systemTime from orderAlarms
where systemTime in (SELECT MAX(systemTime)FROM orderAlarms WHERE emailStatus='1'GROUP BY iceName,orderPath,exceptionType
)

运行结果:

此时已经满足查询要求,可以多添加几条数据作为查询验证。

注:截图中id为6和id为15不是同一种类型的数据,前边?????为数据库中文乱码,实际中文不一样。

数据库乱码戳》》》MySQL5.7乱码问题 


http://chatgpt.dhexx.cn/article/S727HrxD.shtml

相关文章

SQL分组后将不存在的组记为0

说明 最近遇到这么一个需求&#xff1a;统计区间在0-2000,2000-3000,3000-4000,4000-5000,5000工资的人数。 快速开始 数据如下&#xff1a; 开始看到这个问题&#xff0c;想都没想就开始写了下面的代码&#xff1a; SELECT casewhen salary < 2000 then [0, 2000)when …

SQL 分组条件深入剖析

问题 在 stackoverflow 网站上看到这样一个 SQL 分组条件的需求&#xff0c;需求看似挺简单&#xff0c;但能把 SQL 写正确对于新手来说也不容易&#xff0c;我们拿过来深入剖析一下&#xff0c;数据如下&#xff1a; 需求是查找只有Ready 状态的设备。 解答 自然思路&#xff…

SQL分组排序函数(组内分别排序)

建表并插入数据 -- 部门表 create table dept( deptno int primary key auto_increment, -- 部门编号 dname varchar(14) , -- 部门名字 loc varchar(13) -- 地址 ) ; -- 员工表 create table emp( empno int primary key auto_increment,-- 员工编号 …

sql 分组 行列转换

sql 分组 & 行列转换 文章目录 sql 分组 & 行列转换1、groupby&#xff08;配合组合函数使用&#xff09;2、Sql的行列转换 - 纵横表1&#xff09;纵表转横表2&#xff09;横表转纵表 sql语句教程参考W3C School - SQL 教程 就够了 1、groupby&#xff08;配合组合函数…

SQL:分组数据

分组数据&#xff1a; A. SQL Server Group By语句 Group By 从字面意义上理解就是根据“By”指定的规则对数据进行分组&#xff0c;所谓的分组就是将一个“数据集” 划分成若干个“小区域”&#xff0c;然后针对若干个“小区域”进行数据处理。 以下是 GROUP BY 子句的语…

SQL语言中的分组数据

&#xff08;1&#xff09;group by子句 group by 根据by指定的规则对数据进行分组。 分组&#xff1a;即将一个“数据集”划分成若干个“小区域”&#xff0c;再对若干个“小区域”进行数据处理。 语法&#xff1a; group by 子句为列中的每个值组合生成一个组。 group by子…

SQL分组指南

目录 什么是SQL分组&#xff1f; SQL GROUP BY和Sum 排序分组结果 HAVING和GROUP BY 包含多个表的GROUP BY 按SUM()排序 带有表达式的GROUP BY SQL GROUP BY与DISTINCT 结论 什么是SQL分组&#xff1f; 在SQL中&#xff0c;分组是唯一的列值组合。当查询具有GROUP BY…

单例模式的使用和应用场景

1.概念 标题单例模式&#xff1a;单例指的是单实例&#xff0c;一个类中有且仅有创建一个实例 单例模式的应用场景&#xff1a;windows的任务管理器(不可打开两次吧)、回收站等 单例模式应用一般发现在以下条件下&#xff1a; servlet单例、struts2多例、springmvc单例 &…

单例模式实战应用

理论 什么是单例模式 保证整个系统中一个类只有一个对象的实例&#xff0c;实现这种功能的方式就叫单例模式 常用的 service 和 dao 层的对象通常都是单例的&#xff0c;而多例则指每个请求用一个新的对象来处理&#xff0c;比如 action spring 中的 bean 和 spring mvc 中…

单例模式php应用场景,php单例模式 使用场景和使用方法

一个类只有一个对象实例 1、含义 作为对象的创建模式&#xff0c;单例模式确保某一个类只有一个实例&#xff0c;而且自行实例化并向整个系统全局地提供这个实例。它不会创建实例副本&#xff0c;而是会向单例类内部存储的实例返回一个引用。 2、单例模式的三个要点&#xff1a…

Java设计模式及应用场景之《单例模式》

文章目录 一、单例模式定义二、单例模式的结构和说明三、懒汉式和饿汉式的实现1、懒汉式2、饿汉式 四、懒汉式和饿汉式的优缺点五、双重检查加锁方式的实现六、类级内部类方式的实现七、枚举方式的实现 (最佳方式)八、单例模式的应用场景 一、单例模式定义 保证一个类只能有一个…

一文带你了解 Java 五种单例模式的实现方式以及应用场景

单例模式 什么是单例模式 类的单例设计模式&#xff0c;就是采取一定的方法保证在整个软件系统中&#xff0c;某个类只能存在一个对象实例&#xff0c;并且这个类会提供一个获取对象实例的方法。 思路&#xff1a;如果让一个类在一个虚拟机里面只能产生一个对象&#xff0c;就…

js设计模式之 单例模式与应用场景

1.介绍 单例模式&#xff08;Singleton Pattern&#xff09;是设计模式中最简单的设计模式之一。这种类型的设计模式属于创建型模式&#xff0c;它提供了一种创建对象的最佳方式。 这种模式涉及到一个单一的类&#xff0c;该类负责创建自己的对象&#xff0c;同时确保只有单个…

单例模式的理解?单例模式如何实现?单例模式应用场景

说说你对单例模式的理解&#xff1f;如何实现&#xff1f; 一、是什么 单例模式&#xff08;Singleton Pattern&#xff09;&#xff1a;创建型模式&#xff0c;提供了一种创建对象的最佳方式&#xff0c;这种模式涉及到一个单一的类&#xff0c;该类负责创建自己的对象&…

设计模式之单例模式应用场景篇

应用场景 我们为什么要使用单例模式呢&#xff1f;它有什么好处&#xff1f; &#xff08;一&#xff09;单例模式可以让我们只创建一个对象从而避免了频繁创建对象导致的内存消耗和垃圾回收。 Servlet是单例模式&#xff0c;我们只需要创建一个Servlet&#xff0c;然后接收请求…

关于getText()的小问题

由一个作业开始的,整完广度优先小作业的时候开始是在代码中指定值进行寻找路径,后面想想还是弄两文本框输入起点和终点更灵活一点好了。谁知道这个JTextField真的让我崩溃了 怎么说应该是我对Java的基础知识没有进行深入了解吧,好吧,我是在今天才知道getText()是在监听事件…

js gettext

test.php 1 <?php2 $localezh_CN;3 if(isSet($_GET["locale"]))$locale $_GET["locale"];4 ?>5 <html>6 <head>7 <link rel"gettext" type"application/x-po" href"./locale/<?php echo $locale ?&…

关于Java getText()方法的问题

这是一个登陆界面的鼠标事件&#xff0c;获取文本区t61的内容&#xff0c;与用户姓名比对&#xff0c;同时验证登陆密码&#xff0c;但是用户姓名比对一直不成功&#xff0c;导致鼠标事件不能反映&#xff0c;页面不能跳转&#xff0c;想知道为什么&#xff0c;求大佬指点。 p…

java的gettext_JAVA里 getText() 是什么意思,怎么用?

展开全部 JAVA里 getText() 的意思是&#xff1a;返回数据窗口控件中 悬浮在当前行列之上的32313133353236313431303231363533e4b893e5b19e31333431366266编辑框中的文本。 在用户修改数据窗口中某项的值时&#xff0c;实际上首先在悬浮 在当前项上的编辑框中进行修改&#xff…

python gettext的使用方法

app.py 里面的print函数输出内容&#xff0c;是会更据你选择的语言平台而改变 将app.py生成.po文件(或者生成.pot文件)&#xff0c;如果是.pot文件需要重命名为.po pygettext.py安装python的时候就自己带着有&#xff0c;去你的安装路径找 python &#xff08;这一步&#xff…