求: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
也就是说每个人的任意两条数据
...全文
193 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
加入

1.6w+

社区成员

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