oracle 去重

Oracle去重

在Oracle中进行去重的SQL语句有以下几种:

1.使用DISTINCT关键字

使用SELECT DISTINCT列名 FROM 表名来选择唯一的值。例如:SELECT DISTINCT column_name FROM table_name;

2.使用GROUP BY子句

使用GROUP BY子句将重复的值分组,并使用聚合函数如COUNT、SUM等对每个组进行操作。例如:SELECT column_name, COUNT(*) FROM table_name GROUP BY column_name;

3.使用ROW_NUMBER函数

使用ROW_NUMBER函数为每行数据分配一个唯一的行号,然后通过筛选行号为1的数据来实现去重。例如:SELECT column_name FROM (SELECT column_name, ROW_NUMBER() OVER (PARTITION BY column_name ORDER BY column_name) AS row_num FROM table_name) WHERE row_num = 1;

4.使用EXISTS子查询

通过在子查询中使用EXISTS关键字来检查是否存在重复的记录,并筛选出唯一的值。例如:SELECT column_name FROM table_name t1 WHERE EXISTS (SELECT 1 FROM table_name t2 WHERE t1.column_name = t2.column_name AND t1.rowid <> t2.rowid);

5. 使用with result

通过在查询中使用 with result 来检查是否存在重复的记录,并筛选出唯一的值。

例如:with result as ( select * from ( select t1.*, ROW_NUMBER() OVER (PARTITION BY column_name ORDER BY column_name desc) RN from table_name t1 ) t2 where t2.RN = 1)

SELECT * FROM RESULT

相关推荐
吃糖的小孩4 小时前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3501 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3501 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3501 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB2 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵2 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils2 天前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
Databend3 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent