Oracle去除重复数据

 更新时间:2022年05月05日 15:39:20   作者:springsnow  
这篇文章介绍了Oracle去除重复数据的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

查询某些字段相同的记录

如:查询col1与col2值相同的记录:

select a.* from table1 a, table1 b where a.id <> b.id and a.col1 = b.col1 and a.col2 = b.col2;

一、用rowid方法:

根据oracle自带的rowid属性进行判断是否存在重复记录。

rowid伪列用于唯一标识物理位置的表行,当用insert插入数据时,会自动生成rowid,与数据一起存放,形如:AAAL=XAAAEAAAAA。

1、查数据:

select * from    table1 a where rowid!=
(select max(rowid) from table1 b where   a.col1 = b.col1 and a.col2 = b.col2;

2、删数据:

保留rowid最大的记录:

delete  from    table1 a where rowid!=
(select max(rowid) from table1 b where   a.col1 = b.col1 and a.col2 = b.col2;

二、group by 方法:

1、查数据:

select * from    table1 a where (a.col1,a.col2) in 
(select col1,col2 from  table1 group by  col1,col2 having count(*)>1)

2、删数据:

删除表中多余的重复记录(多个字段),只保留rowid最小的记录。

delete  from    table1 a where (a.col1,a.col2) in 
(select col1,col2 from  table1 group by  col1,col2 having count(*)>1)
 and rowid not in 
(select min(rowid) from  table1 group by  col1,col2 having count(*)>1)

到此这篇关于Oracle去除重复数据的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Oracle出现超出打开游标最大数的两种解决方法

    Oracle出现超出打开游标最大数的两种解决方法

    当Oracle数据库中打开的游标数超过了数据库的最大游标数限制时,就会出现“超出打开游标最大数”的错误,本文给大家介绍了几种常见的解决方法,需要的朋友可以参考下
    2024-02-02
  • Oracle数据库rownum和row_number的不同点

    Oracle数据库rownum和row_number的不同点

    在Oracle中,有一个很有趣的东西,那就是rownum。当你从某个表中查询数据的时候,返回的结果集中都会带有rownum这个字段,而且有时候也可以使用rownum进行一些条件查询
    2015-11-11
  • catalog方式的rman备份与恢复示例

    catalog方式的rman备份与恢复示例

    这篇文章主要介绍了catalog方式的rman备份与恢复,需要的朋友可以参考下
    2014-03-03
  • PLSQL Developer连接oracle数据库配置教程

    PLSQL Developer连接oracle数据库配置教程

    这篇文章主要介绍了PLSQL Developer连接oracle数据库配置步骤,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • Oracle使用fy_recover_data恢复truncate删除的数据

    Oracle使用fy_recover_data恢复truncate删除的数据

    这篇文章主要介绍了Oracle使用fy_recover_data恢复truncate删除的数据,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
    2022-07-07
  • Oracle数据库如何删除归档日志文件

    Oracle数据库如何删除归档日志文件

    这篇文章主要给大家介绍了关于Oracle数据库如何删除归档日志文件的相关资料,当Oracle中的归档日志空间满时,则需要把它清空,否则将会影响数据库正常运行,将无法正常登入ORACLE,需要的朋友可以参考下
    2023-11-11
  • oracle错误ORA-00054资源正忙解决办法

    oracle错误ORA-00054资源正忙解决办法

    ORA-00054是Oracle数据库中的一个常见错误,表示用户试图在正在被锁定的资源上执行不允许的操作,导致资源处于忙碌状态,下面这篇文章主要给大家介绍了关于oracle错误ORA-00054资源正忙的解决办法,需要的朋友可以参考下
    2024-01-01
  • Oracle中序列(Sequence)示例详解

    Oracle中序列(Sequence)示例详解

    序列(SEQUENCE)是序列号生成器,可以为表中的行自动生成序列号,产生一组等间隔的数值(类型为数字)。不占用磁盘空间,占用内存,这篇文章主要介绍了Oracle中序列(Sequence)详解,需要的朋友可以参考下
    2023-09-09
  • Oracle中TIMESTAMP的几种类型介绍与实例

    Oracle中TIMESTAMP的几种类型介绍与实例

    我们都知道date和timestamp都是对日期和时间的表示,只是两种类型的精确度不同,前者精确到秒,后者精确到小数秒(fractional_seconds_precision),可以是 0 to 9,缺省是6。这篇文章主要介绍了Oralce中TIMESTAMP的几种类型。有需要的朋友们可以参考借鉴。
    2016-12-12
  • oracle中的greatest 函数和 least函数示例代码

    oracle中的greatest 函数和 least函数示例代码

    这篇文章主要介绍了oracle中的greatest 函数和 least函数的实例代码,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2018-11-11

最新评论