oracle 删除指定字段重复的记录

  1. SQL> select * from t;  
  2.   
  3.         ID NAME            SCORE  
  4. ———- ———- ———-  
  5.          3 smith             100  
  6.          4 smith             100  
  7.          5 jerry              80  
  8.          6 tom                80  
  9.          1 evan              100  
  10.          2 evan              100  
  11.          7 evan              100  
  12.   
  13. 已选择7行。  
  14.   
  15. SQL> ed tmp.buf  
  16.   
  17. SQL> –获取所有的记录,但name与score两者不能重复  
  18. SQL> –哪些字段相同,以哪些字段分组,然后获取其最小的id  
  19. SQL> select min(id) id,name,score from t group by name,score;  
  20.   
  21.         ID NAME            SCORE  
  22. ———- ———- ———-  
  23.          6 tom                80  
  24.          3 smith             100  
  25.          1 evan              100  
  26.          5 jerry              80  
  27.   
  28. SQL> ed tmp.buf  
  29.   
  30. SQL> –获取有重复记录的数据(有重复说明分组后count(*)>1),并且其id最小的记录  
  31. SQL> –哪些字段相同,以哪些字段分组,然后获取其最小的id  
  32. SQL> select min(id) id,name,score from t group by name,score having count(*) > 1;  
  33.   
  34.         ID NAME            SCORE  
  35. ———- ———- ———-  
  36.          3 smith             100  
  37.          1 evan              100  
  38.   
  39. SQL> ed tmp.buf  
  40.   
  41. SQL> –删除那些name与score重复的记录,只保留id最小的那一条  
  42. SQL> DELETE FROM t  
  43.   2   WHERE t.ID NOT IN (SELECT MIN(id) AS id FROM t GROUP BY NAME, score);  
  44.   
  45. 已删除3行。  
  46.   
  47. SQL> select * from t;  
  48.   
  49.         ID NAME            SCORE  
  50. ———- ———- ———-  
  51.          3 smith             100  
  52.          5 jerry              80  
  53.          6 tom                80  
  54.          1 evan              100  
SQL> select * from t;

        ID NAME            SCORE
---------- ---------- ----------
         3 smith             100
         4 smith             100
         5 jerry              80
         6 tom                80
         1 evan              100
         2 evan              100
         7 evan              100

已选择7行。

SQL> ed tmp.buf

SQL> --获取所有的记录,但name与score两者不能重复
SQL> --哪些字段相同,以哪些字段分组,然后获取其最小的id
SQL> select min(id) id,name,score from t group by name,score;

        ID NAME            SCORE
---------- ---------- ----------
         6 tom                80
         3 smith             100
         1 evan              100
         5 jerry              80

SQL> ed tmp.buf

SQL> --获取有重复记录的数据(有重复说明分组后count(*)>1),并且其id最小的记录
SQL> --哪些字段相同,以哪些字段分组,然后获取其最小的id
SQL> select min(id) id,name,score from t group by name,score having count(*) > 1;

        ID NAME            SCORE
---------- ---------- ----------
         3 smith             100
         1 evan              100

SQL> ed tmp.buf

SQL> --删除那些name与score重复的记录,只保留id最小的那一条
SQL> DELETE FROM t
  2   WHERE t.ID NOT IN (SELECT MIN(id) AS id FROM t GROUP BY NAME, score);

已删除3行。

SQL> select * from t;

        ID NAME            SCORE
---------- ---------- ----------
         3 smith             100
         5 jerry              80
         6 tom                80
         1 evan              100
此外还可以使用临时表的方式,即将我们需要的数据(没有重复的数据)先放到临时表中,然后删除正式表中的数据,最后将临时表中的数据插入到正式表中。
但是效率如何我还不知道哩,没有测试哩!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值