视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle去掉表重复数据
2020-11-09 10:43:16 责编:小采
文档


今天在做项目过程中,碰到Oracle数据库表存在重复记录,显示的时候需要去掉重复的数据。想了老半天,最终用rank() over (partiti

今天在做项目过程中,碰到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

推荐阅读:

Oracle比较快的删除重复数据的方式

使用临时表删除Oracle重复数据

Oracle 删除重复数据只留一条

Opendedup 1.1.6 发布,重复数据删除案

下载本文
显示全文
专题