有一张学生表,分别有 id,name,age,chinese,math,english 六个字段,如何查出年龄小于 20,总成绩前三的学生名字? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
singleion
V2EX    Oracle

有一张学生表,分别有 id,name,age,chinese,math,english 六个字段,如何查出年龄小于 20,总成绩前三的学生名字?

  •  
  •   singleion 2018-04-24 16:41:47 +08:00 3437 次点击
    这是一个创建于 2795 天前的主题,其中的信息可能已经有所发展或是发生改变。
    17 条回复    2018-04-25 17:48:22 +08:00
    shiji
        1
    shiji  
       2018-04-24 16:58:00 +08:00 via Android
    年龄那个很简单。
    难点在前三的定义。
    A 简单粗暴分数从大到小排列。如果四个人都是满分,只能显示三个,而且并列的时候排名不公平
    B 考虑并列,先找出三种最高成绩,然后反查学生。100 100 99 99 98 98 98 (两个第一 两个第二 三个第三)
    C 考虑并列。100 100 99 99 (两个并列第一,两个并列第三,没有第二)
    misaka19000
        2
    misaka19000  
       2018-04-24 17:06:47 +08:00
    给 50 块钱就帮你写
    swirling
        3
    swirling  
       2018-04-24 17:09:08 +08:00
    请独立完成作业
    WildCat
        4
    WildCat  
       2018-04-24 17:12:58 +08:00
    SELECT *, (chinese + math + english) as sum_mark FROM students WHERE age < 20 ORDER BY sum_mark LIMIT 3;

    这个问题很难么?
    Kilerd
        5
    Kilerd  
       2018-04-24 22:31:47 +08:00
    某某同学,请独立完成 SQL 课程相关作业。
    singleion
        6
    singleion  
    OP
       2018-04-25 08:45:19 +08:00
    这条 sql 好像是错的!大神!
    singleion
        7
    singleion  
    OP
       2018-04-25 08:45:45 +08:00
    @WildCat 这条 sql 好像是错的!大神!
        8
    singleion  
    OP
       2018-04-25 08:46:14 +08:00
    singleion
    singleion
        9
    singleion  
    OP
       2018-04-25 08:49:07 +08:00
    @swirling 这不是作业,我只是想练习 sql 文
    singleion
        10
    singleion  
    OP
       2018-04-25 08:57:25 +08:00
    @shiji 理解不了您的思路啊!我 sql 能力很弱,这个就是我在学习的练习题!
    wd
        11
    wd  
       2018-04-25 09:24:40 +08:00 via iPhone
    感觉题目有点问题 是在小于 20 的人里面找前三 还是在前三里面找小于 20 的?
    singleion
        12
    singleion  
    OP
       2018-04-25 09:31:57 +08:00
    @wd 年龄小于 20 的条件下,在进行前三学生姓名查询,不矛盾啊!
    shiji
        13
    shiji  
       2018-04-25 09:33:17 +08:00
    @singleion 我的那个跟 SQL 没关系啊。 只是想问你怎么定义前三名。
    shiji
        14
    shiji  
       2018-04-25 09:35:48 +08:00
    @singleion
    也就是假设
    A 总共 100 分
    B 总共 100 分
    C 总共 99 分
    D 总共 99 分
    E 总共 98 分
    那么你期望的输出是什么?
    singleion
        15
    singleion  
    OP
       2018-04-25 14:13:49 +08:00
    就是年龄 20 以内,总分排名前三的学生"姓名"查出来即可!
    singleion
        16
    singleion  
    OP
       2018-04-25 14:14:17 +08:00
    @shiji 就是年龄 20 以内,总分排名前三的学生"姓名"查出来即可!
    singleion
        17
    singleion  
    OP
       2018-04-25 17:48:22 +08:00
    @shiji select * from (
    select * from (
    select sum(t.CHINESE + t.MATH + t.ENGLISH) cj,t.name from student t where t.age<20 group by t.name ) t2
    order by t2.cj desc )where rownum < 4
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2758 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 26ms UTC 14:48 PVG 22:48 LAX 06:48 JFK 09:48
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86