google搜索 站内搜索                 软件测试门户 | 软件测试培训 | 文章资料精选 | 软件测试论坛 | 测试解决方案 | 软件测试博客 | 测试招聘求职 
打印

[原创] 共享一SQL面试题

共享一SQL面试题


有一个表LEANR,表里有三个字段分别是学生ID(student_id),课程(kc),成绩(grade),要求用一条查询语句搜索出每一门课程的前两名。
答案:select student_id,kc,grade from (select student_id,kc,grade,number=(select count(distinct grade) from learn where t.kc=kc and t.grade<grade) from learn t ) tt where number>2

[ 本帖最后由 dandan 于 2007-4-12 12:18 编辑 ]
悄悄,是离别的笙箫,
沉默,是今晚的康桥。

TOP

谢谢机楼主..

TOP

thanks


thanks very much

TOP

实在太好了

TOP

不知道我的对不,很久没写SQL了
select top 2 *
from (select * from learn order by grade desc)
where kc in (select distinct (kc) from learn)
当黑夜过去总会有阳光

TOP

select top 2 *
from (select * from learn order by kc, grade desc) a
where a.kc in (select distinct (kc) from learn)
当黑夜过去总会有阳光

TOP

楼主的SQL错了

select  student_id, kc,grade from (
select  student_id,kc,grade,row_number over (partition by kc order by grade desc) rn from  leanr
) where  rn<=2

TOP

很不错

TOP

谁的语句是对的

TOP

3Q

TOP

select b.student_id,b.kc,grade,b.number
from (select student_id,kc,grade,number=(select count(*) from leanr where  kc=t.kc and grade>=t.grade )
      from leanr t) b
where b.number<=2
order by b.kc,b.grade desc,b.number

[ 本帖最后由 Helen_px 于 2007-11-7 11:32 编辑 ]

TOP

我感觉6楼的对的

TOP

我建过表验证过了,#11是对的。

TOP

回复 13# 的帖子


学习下

TOP

本功能由奇虎搜索实现

相关主题

标题 作者 最后发表
做软件开发 测试的!需要的请进! lan3344 2008-11-18
求网络工程师面试题及答案! fengyun32 2008-10-20
我能干软件测试吗 郭大路 2008-11-17
测试生活 默默巫1 2008-11-06
点击阅读更多关于的相关帖子  更多相关主题
 
当前时区 GMT+8, 现在时间是 2008-12-3 02:35Copyright(C)上海博为峰软件技术有限公司 2001-2007 电话:021-64471599-8017
当您在访问网站、论坛及博客过程中遇到问题时可发送email:webmaster@51testing.com或发送论坛短信至管理员风在吹