51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 10524|回复: 16
打印 上一主题 下一主题

[求助] 共享一SQL面试题

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2007-4-12 11:49:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
有一个表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 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2007-4-18 16:13:26 | 只看该作者
谢谢机楼主..
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2007-4-25 13:55:54 | 只看该作者

thanks

thanks very much
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2007-9-20 19:37:29 | 只看该作者
实在太好了
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2007-9-30 22:38:15 | 只看该作者
不知道我的对不,很久没写SQL了
select top 2 *
from (select * from learn order by grade desc)
where kc in (select distinct (kc) from learn)
回复 支持 反对

使用道具 举报

该用户从未签到

6#
发表于 2007-9-30 22:44:22 | 只看该作者
select top 2 *
from (select * from learn order by kc, grade desc) a
where a.kc in (select distinct (kc) from learn)
回复 支持 反对

使用道具 举报

该用户从未签到

7#
发表于 2007-10-11 09:54:17 | 只看该作者
楼主的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
回复 支持 反对

使用道具 举报

  • TA的每日心情
    无聊
    2014-12-23 08:50
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    8#
    发表于 2007-10-19 08:54:25 | 只看该作者
    很不错
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    9#
    发表于 2007-10-28 01:49:11 | 只看该作者
    谁的语句是对的
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    郁闷
    2017-1-18 14:45
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    10#
    发表于 2007-11-1 13:05:52 | 只看该作者
    3Q
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    11#
    发表于 2007-11-7 11:02:44 | 只看该作者
    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 编辑 ]
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    12#
    发表于 2007-11-21 15:02:07 | 只看该作者
    我感觉6楼的对的
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    13#
    发表于 2008-3-18 14:08:27 | 只看该作者
    我建过表验证过了,#11是对的。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    14#
    发表于 2008-3-19 14:27:00 | 只看该作者

    回复 13# 的帖子

    学习下
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    15#
    发表于 2016-11-21 14:59:53 | 只看该作者
    如果考虑到一样的分数,楼上的sql应该修改下
    select b.id,b.kc,grade,b.number
    from (select id,kc,grade,number=(select count(*) from learn where  kc=t.kc and grade>t.grade )
          from learn t) b
    where b.number<=1
    order by b.kc,b.grade desc,b.number
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2017-2-13 16:28
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    16#
    发表于 2016-11-30 15:37:36 | 只看该作者
    楼主给的语句在postgresql 试了一下。

    ERROR: column "num" does not exist
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2017-2-13 16:28
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    17#
    发表于 2016-11-30 16:36:45 | 只看该作者
    在 postgresql 试了一下

    select course,student,grade,row_id from
    (select *,row_number() over (partition by course order by grade desc) as row_id from learn) as l where row_id<3 order by course

    可以完美解决相同分数的问题
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-27 02:42 , Processed in 0.076893 second(s), 26 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表