oracle去掉表重复数据

      今天在做项目过程中,碰到数据库表存在重复记录,显示的时候需要去掉重复的数据。想了老半天,最终用rank() over (partition by 分组字段 order by 排序字段 顺序)
解决了此问题。

     一、首先介绍下rank() over (partition by 分组字段 order by 排序字段 顺序):

     语法:
              rank() over (order by 排序字段 顺序)
              rank() over (partition by 分组字段 order by 排序字段 顺序)

             1.顺序:asc|desc  名次与业务相关:
             2.分区字段:根据什么字段进行分区。

     问题:分区与分组有什么区别?
     •分区只是将原始数据进行名次排列(记录数不变),
     •分组是对原始数据进行聚合统计(记录数变少,每组返回一条)。

    注意:使用rank()over(order by 排序字段 顺序)排序的时候,空值是最大的
                 (如果排序字段为null,可能造成在排序时将null字段排在最前面,影响排序的正确性。
                所以建议将dense_rank()over(order by 列名 排序)改为dense_rank()over(order by 列名 排序 nulls last)
                这样只要排序字段为null,就会放在最后,而不会影响排序结果)。

    二、例子

           首先创建一张test表,f分别有id,no两个字段,这张表中的数据为:

           id     no

           1      11

           2      22

           3      22

           4      33

           5      55

          需要将此表中no字段中的22重复数据去掉一条,SQL语句为:

          select b.id,b.no from (
          select rank() over(partition BY t.no order by t.id) aa,t.* from test t) b
          where b.aa=1

          执行结果为:
          id     no

           1      11

           2      22

           4      33

           5      55

 

           

 


   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值