oracle/mysql数据库多条重复数据如何取最新的

 更新时间:2024年08月09日 09:35:33   作者:多来哈米  
最近开发的时候遇到一个任务,需要对重复的数据进行筛选,只取插入时间最早的一条数据,这篇文章主要给大家介绍了关于oracle/mysql数据库多条重复数据如何取最新的相关资料,需要的朋友可以参考下

MYSQL

1、分组取最新的,再用最新的字段连表,回查数据

①按分组字段取最新的,通过主键id回表查数据

select * from table_name
WHERE id in (
select max(id) id from table_name GROUP BY 分组字段)

②非主键字段

SELECT r.*
FROM records r
INNER JOIN (
    SELECT group_id, MAX(timestamp) as latest
    FROM records
    GROUP BY group_id
) as latest_records 
ON r.group_id = latest_records.group_id 
AND r.timestamp = latest_records.latest;

ORACLE

1、原理讲解-可直接看2

筛选出最新的

SELECT *  
FROM (  
    SELECT t.*,  
           ROW_NUMBER() OVER (PARTITION BY LOCALAUTHID ORDER BY LASTUPDATETIME DESC) AS rn  
    FROM USER_LOCALAUTH_STATE t  
) t  
WHERE t.rn = 1;

解释:

这个序号是基于[LOCALAUTHID]字段进行分区的(即每个[LOCALAUTHID]值都是一个新的分区),并且在每个分区内部,行是按照LASTUPDATETIME字段降序排列的

2、在重复数据取最新的

SELECT *  
FROM (  
    SELECT t.*,ROW_NUMBER() OVER (PARTITION BY LOCALAUTHID ORDER BY LASTUPDATETIME DESC) AS rn  
    FROM    
		(
			-- 筛选存在重复的数据,count(LOCALAUTHID) > 1
			select * from USER_LOCALAUTH_STATE
			where LOCALAUTHID	in (
				SELECT LOCALAUTHID
				FROM USER_LOCALAUTH_STATE WHERE STATE = 1 AND BUSINESSTYPE=1
				group by LOCALAUTHID having count(LOCALAUTHID) > 1)
		) t
	) rt  
WHERE rt.rn = 1;

3、若要删除不满足条件

在2的基础上,通过[LOCALAUTHID]查询,并删除ID不再2中的

附:ORACLE 查询某个时间之前的重复数据中时间最早的一条记录

接到任务,查询2021年之前的US_ADDCONSIGN表中用户信息。

同时同事告知,有用户重复注册所以信息有重复的,要求重复的信息中获取目前仍有效,且注册时间最早的那一条记录。

select * from (select row_number() over (partition by certno order by consigndate) rn, a.* from US_ADDCONSIGN a where 1=1 and state=1 ) where rn=1 and to_date(consigndate,'yyyymmdd')<to_date('20210101','yyyymmdd');

总结 

到此这篇关于oracle/mysql数据库多条重复数据如何取最新的文章就介绍到这了,更多相关sql多条重复数据取最新内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • linux下使用RPM安装mysql5.7.17

    linux下使用RPM安装mysql5.7.17

    这篇文章主要为大家详细介绍了linux下使用RPM安装mysql5.7.17的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • SQL IDENTITY_INSERT作用案例详解

    SQL IDENTITY_INSERT作用案例详解

    这篇文章主要介绍了SQL IDENTITY_INSERT作用案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 深入解析MySQL 事务

    深入解析MySQL 事务

    这篇文章主要给大家分享的是mysql事务解析,事务(transaction)是业务逻辑的一个基本的单元组成,下面文章围绕mysql事务的相关资料展开详细内容,需要的朋友可以参考一下希望对大家有所帮助
    2022-01-01
  • 从基础语法到最佳实践详解SQL分页查询完整指南

    从基础语法到最佳实践详解SQL分页查询完整指南

    在数据库查询中,分页(Pagination) 是一项基本且关键的技术,本文将从 SQL分页的基础语法 讲起,逐步深入探讨 不同数据库的分页实现方式,有需要的小伙伴可以了解下
    2025-07-07
  • MySQL官方导出工具mysqlpump的使用

    MySQL官方导出工具mysqlpump的使用

    备份恢复是 DBA 绕不开的核心话题,市面上也有很多开源的备份恢复方案,不过官方的 mysqldump 一直是处于鄙视链底端的那个。终于,官方在 MySQL5.7 之后新添加了一个备份工具:mysqlpump,本文将简单的介绍该工具的使用
    2021-05-05
  • MySQL数据库表的CRUD操作

    MySQL数据库表的CRUD操作

    这篇文章主要介绍了MySQL数据库表的CRUD操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-05-05
  • 通过.ibd文件恢复MySQL数据的全流程

    通过.ibd文件恢复MySQL数据的全流程

    .ibd 文件是 InnoDB 存储引擎的核心数据文件,存储表的行数据、索引及元信息,本文主要为大家介绍了通过.ibd文件恢复MySQL数据的全流程,需要的朋友可以参考下
    2025-11-11
  • mysql数据库的全量与增量的备份以及恢复方式

    mysql数据库的全量与增量的备份以及恢复方式

    在数据库管理中,全量备份与恢复是将整个数据库的数据导出并在需要时完整地恢复,这通常使用mysqldump工具完成,增量备份则是在全量备份的基础上,只备份那些自上次全量备份后发生变化的数据,这需要数据库的二进制日志(binlog)开启
    2024-09-09
  • MySQL每日练习之单表查询

    MySQL每日练习之单表查询

    这篇文章主要给大家介绍了关于MySQL每日练习之单表查询的相关资料,数据库管理系统的一个最重要的功能就是数据查询,数据查询不应只是简单查询数据库中存储的数据,还应该根据需要对数据进行筛选,需要的朋友可以参考下
    2023-07-07
  • IDEA连接mysql又报错!Server returns invalid timezone. Go to tab and set serverTimezone  prope的问题

    IDEA连接mysql又报错!Server returns invalid timezone. Go to tab an

    这篇文章主要介绍了IDEA连接mysql又报错!Server returns invalid timezone. Go to 'Advanced' tab and set 'serverTimezone' prope问题,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2020-05-05

最新评论