zoukankan      html  css  js  c++  java
  • 由于row_number() over 是Oracle中的函数,MySQL如何实现相同功能?

    示例:想要取出每个课程前3名的学生信息、课程id,成绩与对应课程内排名

    创建student表:
    s_id为学生id,s_name为学生姓名,s_sex为性别
    创建score表:
    s_id 为学生id,c_id为课程id,s_score为对应的成绩

     

    #内嵌部分:
    set @rank:=0;
    select *, @rank:=case when @current_id<>c_id then 1 else @rank+1 end as rank,
           @current_id:=c_id
    from score 
    order by c_id, s_score desc;
    注意:@current_id=c_id,当c_id不是当前的课程时,rank重新从1开始计数,否则在当前rank上加1,@current_id赋值次序不能错,第一个正好未赋值,case when @current_id<>c_id 成立then 1执行
    此时的排序需要现基于课程id,再基于成绩逆序
     
    #整体连起来写:
    set @rank:=0;
    select a.*, b.c_id, b.s_score, b.rank 
    from(select *, @rank:=case when @current_id<>c_id then 1 else @rank+1 end as rank, @current_id:=c_id 
         from score 
         order by c_id,s_score desc)b
    left join student a 
    on a.s_id=b.s_id
    having rank<=3
    order by c_id, rank

     注意:在最后的条件设定中需要用having不能用where,因为在原表中是不存在rank字段的,这是我们为了取数所构造的

  • 相关阅读:
    当当网css代码
    当当网代码6
    游戏UI设计(2.1)窗口之父CXWnd的封装
    英语(1)备考——词汇
    UML的五类图(UML笔记)
    Sieve of Eratosthenes[ZT]
    std::map初体验
    “非计算机相关专业”的定义
    英语(1)备考——翻译
    使用回调函数发送自定义“消息”
  • 原文地址:https://www.cnblogs.com/sx66/p/13476846.html
Copyright © 2011-2022 走看看