zoukankan      html  css  js  c++  java
  • oracle重复数据处理

    数据库操作中,经常会因为导数据造成数据重复,需要进行数据清理,去掉冗余的数据,只保留正确的数据
    一:重复数据根据单个字段进行判断
    1、首先,查询表中多余的数据,由关键字段(name)来查询。
    select * from OA_ADDRESS_BOOK where name in (select name from OA_ADDRESS_BOOK group by name having count(name)>1)
    2、删除表中重复数据,重复数据是根据单个字段(Name)来判断,只留有rowid最小的记录
    delete from OA_ADDRESS_BOOK where (Name) in
    (select Name from OA_ADDRESS_BOOK group by Name having count(Name) >1)
    and rowid not in (select min(rowid) from OA_ADDRESS_BOOK group by Name having count(Name)>1)

    二:重复数据根据多个字段进行判断
    1、首先,查询表中重复数据,由关键字段(Name,UNIT_ID)来查询。
    select * from OA_ADDRESS_BOOK book1 where (book1.name,book1.unit_id) in
    (select book2.name,book2.unit_id from OA_ADDRESS_BOOK book2 group by  book2.name,book2.unit_id  having count(*)>1)
    2、删除表中重复数据,重复数据是根据多个字段(Name,UNIT_ID)来判断,只留有rowid最小的记录
    delete from OA_ADDRESS_BOOK a where (a.Name,a.UNIT_ID) in
    (select Name,UNIT_ID from OA_ADDRESS_BOOK group by Name,UNIT_ID having count(*) > 1)
    and rowid not in (select min(rowid) from OA_ADDRESS_BOOK group by Name,UNIT_ID having count(*)>1)

    3、查询表中重复数据,重复数据是根据多个字段(Name,UNIT_ID)来判断,不包含rowid最小的记录

    select name,unit_id from OA_ADDRESS_BOOK a where (a.Name,a.UNIT_ID) in
    (select Name,UNIT_ID from OA_ADDRESS_BOOK group by Name,UNIT_ID having count(*) > 1)
    and rowid not in (select min(rowid) from OA_ADDRESS_BOOK group by Name,UNIT_ID having count(*)>1)

    参考博客:http://blog.csdn.net/u010069853/article/details/53517895

  • 相关阅读:
    Solr7使用Oracle数据源导入+中文分词
    自动签发https证书工具 cert manager
    Docker容器服务发现方案
    Registrator中文文档
    C#重试公用类
    sqlserver 2017 docker安装(启动代理)
    【转】如何将MySQL数据目录更改为CentOS 7上的新位置
    solr搜索引擎配置使用mongodb作为数据源
    [转]Docker容器可视化监控中心搭建
    AOP缓存实现
  • 原文地址:https://www.cnblogs.com/cyf18/p/14285290.html
Copyright © 2011-2022 走看看