免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3441 | 回复: 5
打印 上一主题 下一主题

求查询表里前10名的最大 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-02 09:15 |只看该作者 |倒序浏览
我有一个表里面大约有以下字段:
jgm,hm,ye
内容比如如下:
机构比如大约10个机构,jgm大约为1,2,3,4,5,6,7,8,9,10
hm任意,ye任意

现在如何统计这10个机构所对应的最大前10户ye的表,也就是这个表里,按jgm选择出前10户

如下结果:
1,A,90
1,B,80
1,c ,70
....
1,10,10
2,A,90
2,A,80
2,b,70
...
3
....
4...
..
10..
就是这个结果呢,每一个机构都选出前10户,我这里是10个机构,其实我那有50个呢,所以不可能按jgm=某个选择,那样要手工50多次,请问各位有什么好办法,十分感谢帮助

论坛徽章:
0
2 [报告]
发表于 2009-07-04 21:59 |只看该作者
select jgm,hm,ye from (select jgm,hm,ye,row_number() over (partition by jgm order by ye desc) as rn  from yourtable) where rn<=10;

论坛徽章:
0
3 [报告]
发表于 2009-07-04 22:46 |只看该作者
啥时候支持这种语法了? 呵呵。跟oracle一样?

论坛徽章:
0
4 [报告]
发表于 2009-07-05 09:38 |只看该作者
原帖由 ivhb 于 2009-7-4 22:46 发表
啥时候支持这种语法了? 呵呵。跟oracle一样?

OLAP函数DB2V6就有了,ORACLE8.1.6引入的。

论坛徽章:
0
5 [报告]
发表于 2009-07-06 17:40 |只看该作者
脚本好像有问题啊,运行提示什么as错误,找不到原因呢

论坛徽章:
0
6 [报告]
发表于 2009-07-06 17:47 |只看该作者
可以了,谢谢2楼的好朋友
select jgm,hm,ye from (select jgm,hm,ye,row_number() over (partition by jgm order by ye desc) rn  from yourtable) as c where c.rn<=10;

此贴结束
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP