时间:2021-07-01 10:21:17 帮助过:4人阅读
1、使用 distinct 关键字 (oracle查询数据中,不允许非 distinct 标注字段 )
select count(distinct a),a,b,c from test_table;
2、使用 group by (oracle查询数据中不允许非分组字段)
select a,b,c from test_table group by a;
解决方案:使用row_number() over( partition by) 方法分组排序
with temp as (
select a,b,c from test_table
)
select a,b,c from (
select a,b,c,row_number() over (partition by a order by rownum) row_no from temp
) where row_no = 1
ps: with temp as() 括号内的内容 就是查询的sql 结果包含重复数据
row_number() over(partition by 需要检索重复的列 order by 排序的列名) 别名 row_no ,如果分组存在多条相同值,row_no 从1开始递增,筛选 row_no = 1 ,就取到了只出现一次的数据
参考:https://blog.csdn.net/u014481096/article/details/82144519
Oracle 单列去重 显示单行所有列数据
标签:https image 排序 acl bsp 图片 distinct img 别名