热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Oraclerow_number分析函数简化了我们的很多操作

1880213009060195918830130090633337分析:这不是一个很难的问题,*********分组统计***

18802 13009060195 9 18830 13009063333 7 //分析: //这不是一个很难的问题, /*********分组统计***

Oracle row_number分析函数简化了我们的很多操作

[日期:2011-05-04] 来源:Linux社区 作者:BOBO12082119 [字体:]

//问题:
CI MSISDN CNT
18802 13009060195 9
18830 13009060195 1
18837 13009060195 2
18829 13009063333 5
18830 13009063333 7
18847 13009063333 4
//结果:
CI MSISDN CNT
18802 13009060195 9
18830 13009063333 7
//此问题是想把MSISDN相同的项的CNT查询出来
//碰到此问题,我是这么思考的:
//首先,将MSISDN相同的项的CNT查询出来,构成一个结果集:
with t as(
select '18802' ci,'13009060195' msisdn,9 cnt from dual union all
select '18830','13009060195',1 from dual union all
select '18837','13009060195',2 from dual union all
select '18829','13009063333',5 from dual union all
select '18830','13009063333',7 from dual union all
select '18847','13009063333',4 from dual)
select msisdn,max(cnt) cnt
from t
group by msisdn
--
MSISDN CNT
----------- ----------
13009060195 9
13009063333 7
//其次,将原表与此结构集相匹配,如果MSISDN和CNT都相同的就提出来
select t.*
from t,(
select msisdn,max(cnt) cnt
from t
group by msisdn
) b
where t.msisdn=b.msisdn and
t.cnt=b.cnt;
//这样就能得到我们想要的结果,如下:
CI MSISDN CNT
----- ----------- ----------
18802 13009060195 9
18830 13009063333 7
//分析:
//这不是一个很难的问题,,
/*********分组统计******/
//可这又是子查询,又是表连接的,怎么那么费事呢?
//肯定还有更好的解决方法:
select ci,msisdn,cnt
from (select ci,
msisdn,
cnt,
row_number()over(partition by msisdn order by cnt desc) rn from t)
where rn=1;

linux

推荐阅读
author-avatar
潘PanPanPq
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有