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

  • 相关阅读:
    C# webservice服务跟踪调试方法(转)
    ServiceBase.OnStart 方法
    基本类型和引用类型
    js基本概念
    在HTML中使用JavaScript
    js中的this
    SQL 取两日期的记录
    常用数据结构[转]
    How to: Pass Values Between ASP.NET Web Pages
    example for store procedure with both transcration and error handling
  • 原文地址:https://www.cnblogs.com/cyf18/p/14285290.html
Copyright © 2011-2022 走看看