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

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

  •  
  •   singleion Apr 24, 2018 3680 views
    This topic created in 2940 days ago, the information mentioned may be changed or developed.
    17 replies    2018-04-25 17:48:22 +08:00
    shiji
        1
    shiji  
       Apr 24, 2018 via Android
    年龄那个很简单。
    难点在前三的定义。
    A 简单粗暴分数从大到小排列。如果四个人都是满分,只能显示三个,而且并列的时候排名不公平
    B 考虑并列,先找出三种最高成绩,然后反查学生。100 100 99 99 98 98 98 (两个第一 两个第二 三个第三)
    C 考虑并列。100 100 99 99 (两个并列第一,两个并列第三,没有第二)
    misaka19000
        2
    misaka19000  
       Apr 24, 2018
    给 50 块钱就帮你写
    swirling
        3
    swirling  
       Apr 24, 2018
    请独立完成作业
    WildCat
        4
    WildCat  
       Apr 24, 2018
    SELECT *, (chinese + math + english) as sum_mark FROM students WHERE age < 20 ORDER BY sum_mark LIMIT 3;

    这个问题很难么?
    Kilerd
        5
    Kilerd  
       Apr 24, 2018
    某某同学,请独立完成 SQL 课程相关作业。
    singleion
        6
    singleion  
    OP
       Apr 25, 2018
    这条 sql 好像是错的!大神!
    singleion
        7
    singleion  
    OP
       Apr 25, 2018
    @WildCat 这条 sql 好像是错的!大神!
    singleion
        8
    singleion  
    OP
       Apr 25, 2018
    singleion
        9
    singleion  
    OP
       Apr 25, 2018
    @swirling 这不是作业,我只是想练习 sql 文
    singleion
        10
    singleion  
    OP
       Apr 25, 2018
    @shiji 理解不了您的思路啊!我 sql 能力很弱,这个就是我在学习的练习题!
    wd
        11
    wd  
       Apr 25, 2018 via iPhone
    感觉题目有点问题 是在小于 20 的人里面找前三 还是在前三里面找小于 20 的?
    singleion
        12
    singleion  
    OP
       Apr 25, 2018
    @wd 年龄小于 20 的条件下,在进行前三学生姓名查询,不矛盾啊!
    shiji
        13
    shiji  
       Apr 25, 2018
    @singleion 我的那个跟 SQL 没关系啊。 只是想问你怎么定义前三名。
    shiji
        14
    shiji  
       Apr 25, 2018
    @singleion
    也就是假设
    A 总共 100 分
    B 总共 100 分
    C 总共 99 分
    D 总共 99 分
    E 总共 98 分
    那么你期望的输出是什么?
    singleion
        15
    singleion  
    OP
       Apr 25, 2018
    就是年龄 20 以内,总分排名前三的学生"姓名"查出来即可!
    singleion
        16
    singleion  
    OP
       Apr 25, 2018
    @shiji 就是年龄 20 以内,总分排名前三的学生"姓名"查出来即可!
    singleion
        17
    singleion  
    OP
       Apr 25, 2018
    @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
    About     Help     Advertise     Blog     API     FAQ     Solana     5650 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 1134ms UTC 08:34 PVG 16:34 LAX 01:34 JFK 04:34
    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