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

相关推荐
hj10431 小时前
redis开启局域网访问
数据库·redis·缓存
源代码•宸2 小时前
MySQL 索引:索引为什么使用 B+树?(详解B树、B+树)
数据结构·数据库·经验分享·b树·mysql·b+树·b-树
睡觉的时候不会困3 小时前
MySQL 数据库表操作与查询实战案例
数据库·mysql
秋已杰爱4 小时前
Redis常见命令
数据库·redis·缓存
一个有梦有戏的人4 小时前
软考架构师:数据库的范式
数据库·oracle
stray小书童5 小时前
neo4j数据库实战
数据库·neo4j
时序数据说5 小时前
时序数据库为什么选IoTDB?
大数据·数据库·物联网·开源·时序数据库·iotdb
{⌐■_■}6 小时前
【MongoDB】简单理解聚合操作,案例解析
数据库·线性代数·mongodb
zuozewei7 小时前
MySQL高可用改造之数据库开发规范(大事务与数据一致性篇)
数据库·mysql·数据库开发
THXW.8 小时前
【Java项目与数据库、Maven的关系详解】
java·数据库·maven