ROW_NUMBER() 分组排序 分组后取时间最大的一条数据

我们简单还原一下,这里使用一个表模拟下

表的字段如下

表的内容如下,我们的需求就是取出相同name的数据中时间最新的一条。

不知道大家首先会想到什么,我第一想到的是使用group,当时认为分组不就是group吗,害,easy

然后我就开始了尝试,结果。。。。。

就在我想要放弃的时候,我突然脑子清醒了,开始仔细思考这个需求,不就是把每个名字和最新的时间拿出来,然后再根据名字和最新时间直接查,不就是最新记录了吗?

那来看看具体咋弄吧。

代码

首先第一步,找出每一个name对应的最新时间

select name, max(dtime) from test group by name;

+------+---------------------+

| name | max(dtime) |

+------+---------------------+

| xw | 2023-05-22 20:01:43 |

| ll | 2023-05-26 20:01:54 |

| oo | 2023-05-03 20:01:56 |

+------+---------------------+

而后我们只需要将上面查询的数据和表中的数据进行左连接即可

select t2.* from (select t.name, max(t.dtime) dtime from test t group by name) t1 left join test t2 on t1.name=t2.name and t1.dtime=t2.dtime;

+----+------+---------------------+------+

| id | name | dtime | info |

+----+------+---------------------+------+

| 2 | xw | 2023-05-22 20:01:43 | 5-22 |

| 5 | ll | 2023-05-26 20:01:54 | 5-26 |

| 6 | oo | 2023-05-03 20:01:56 | 5-03 |

+----+------+---------------------+------+

3 rows in set (0.07 sec)

-- Create table

create table TEST

(

id NUMBER,

name VARCHAR2(20),

dtime DATE,

info VARCHAR2(20)

)

;

insert into test (ID, NAME, DTIME, INFO)

values (1, 'xw', to_date('20-03-2024', 'dd-mm-yyyy'), '2');

insert into test (ID, NAME, DTIME, INFO)

values (2, 'xw', to_date('23-03-2024', 'dd-mm-yyyy'), '3');

insert into test (ID, NAME, DTIME, INFO)

values (3, 'xw', to_date('20-03-2024', 'dd-mm-yyyy'), '4');

insert into test (ID, NAME, DTIME, INFO)

values (4, 'll', to_date('19-03-2024', 'dd-mm-yyyy'), '5');

insert into test (ID, NAME, DTIME, INFO)

values (5, 'll', to_date('20-03-2024', 'dd-mm-yyyy'), '6');

insert into test (ID, NAME, DTIME, INFO)

values (6, 'oo', to_date('11-03-2024', 'dd-mm-yyyy'), '7');

insert into test (ID, NAME, DTIME, INFO)

values (7, 'oo', to_date('27-03-2024', 'dd-mm-yyyy'), '8');

-----方式1

select t.*, t.rowid from test t

--select t2.name from (select t1.* from test t1 order by dtime desc ) t2 group by t2.name

select name, max(dtime) from test group by name;

select t.*, t.rowid from test t

-----方式2

SELECT *

FROM (

SELECT ROW_NUMBER() OVER(

PARTITION BY name ORDER BY dtime DESC

) AS rid, test.*

FROM test

)

WHERE rid = 1;

select t2.* from (select t.name, max(t.dtime) dtime from test t group by name) t1 join test t2 on t1.name=t2.name and t1.dtime=t2.dtime;

-----方式3

mysql8.0之前没有类似oracle 中的row_number()函数,max min 这种只适用于ID列,或者唯一有序列的情况,所以采用这种方式

select a.* from test a where not exists(select 1 from test where name = a.name and dtime > a.dtime)

name是分组字段,dtime排序字段

相关推荐
朝新_1 天前
【实战】动态 SQL + 统一 Result + 登录校验:图书管理系统(下)
xml·java·数据库·sql·mybatis
装不满的克莱因瓶1 天前
什么是脏读、幻读、不可重复读?Mysql的隔离级别是什么?
数据库·mysql·事务·隔离级别·不可重复读·幻读·脏读
aramae1 天前
MySQL数据库入门指南
android·数据库·经验分享·笔记·mysql
Apache IoTDB1 天前
时序数据库 IoTDB 集成 MyBatisPlus,告别复杂编码,简化时序数据 ORM 开发
数据库·struts·servlet·时序数据库·iotdb
isNotNullX1 天前
怎么用数据仓库来进行数据治理?
大数据·数据库·数据仓库·数据治理
小坏讲微服务1 天前
Spring Cloud Alibaba Gateway 集成 Redis 限流的完整配置
数据库·redis·分布式·后端·spring cloud·架构·gateway
HitpointNetSuite1 天前
连锁餐饮行业ERP系统如何选择?
大数据·数据库·oracle·netsuite·erp
一路向北North1 天前
网页版预编译SQL转换工具
前端·javascript·sql
百***17071 天前
MySQL 常用 SQL 语句大全
数据库·sql·mysql
百***65951 天前
mysql如何发现慢查询sql
数据库·sql·mysql