求:oracle SQL 分组后去其中任意两条记录。

haoztao 2013-08-06 11:10:54
比如有如下记录:
col1 col2
张三 A02
张三 C01
张三 A01
张三 B02
李四 A02
李四 C01
李四 A01
李四 B02
王五 A02
王五 C01
王五 A01
王五 B02
想要结果:
col1 col2
张三 A02
张三 C01
李四 C01
李四 A01
王五 A01
王五 B02
也就是说每个人的任意两条数据
...全文
185 点赞 收藏 4
写回复
4 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
super007007007 2013-08-26

SELECT COL1,COL2 FROM 
  (SELECT T.*,ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY DBMS_RANDOM.VALUE) RN FROM T )
  WHERE RN<=2
回复
airelisa 2013-08-26
引用 1 楼 u010412956 的回复:
试试这个sql可否:
 SELECT COL1,COL2 FROM 
  (SELECT T.*,ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2) RN FROM T )
  WHERE RN<=2
学习了
回复
hh7yx 2013-08-06
试试这个sql可否:
 SELECT COL1,COL2 FROM 
  (SELECT T.*,ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2) RN FROM T )
  WHERE RN<=2
回复
aio_o 2013-08-06
分析函数过硬啊...
回复
相关推荐
发帖
Oracle
创建于2007-09-28

1.6w+

社区成员

Oracle开发相关技术讨论
申请成为版主
帖子事件
创建了帖子
2013-08-06 11:10
社区公告
暂无公告