当前位置:数据库 > Oracle >>

oracle去掉表重复数据

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

 

 
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,