今天在做项目过程中,碰到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 no1 112 223 224 335 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) bwhere b.aa=1执行结果为:id no1 112 224 335 55
推荐阅读:Oracle比较快的删除重复数据的方式 http://www.linuxidc.com/Linux/2013-05/83746.htm使用临时表删除Oracle重复数据 http://www.linuxidc.com/Linux/2013-03/82022.htmOracle 删除重复数据只留一条 http://www.linuxidc.com/Linux/2013-03/80655.htmOpendedup 1.1.6 发布,重复数据删除案 http://www.linuxidc.com/Linux/2012-07/66169.htm更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12MySQL 半同步复制(semi_sync_replication)搭建及使用Oracle 11g RAC OCR 与 db_unique_name 配置关系 说明相关资讯 Oracle重复数据 Oracle去掉重复
- 使用临时表删除Oracle重复数据 (03/31/2013 14:46:50)
本文评论 查看全部评论 (0)