码迷,mamicode.com
首页 > 数据库 > 详细

Mysql中实现row_number

时间:2016-12-18 18:07:03      阅读:404      评论:0      收藏:0      [点我收藏+]

标签:efault   test   value   row   having   class   number   into   create   

    CREATE TABLE `zsl_test` (  
        `ID` INT(10) NULL DEFAULT NULL,  
        `class` INT(10) NULL DEFAULT NULL,  
        `score` INT(10) NULL DEFAULT NULL  
    )  
    COLLATE=‘utf8_general_ci‘  
    ENGINE=InnoDB;     



    insert into zsl_test values (1,1,80);  
    insert into zsl_test values (2,1,80);  
    insert into zsl_test values (3,1,80);  
    insert into zsl_test values (4,1,80);  
    insert into zsl_test values (5,2,80);  
    insert into zsl_test values (6,2,80);  
    insert into zsl_test values (7,2,80);  
    insert into zsl_test values (8,2,80);  
    insert into zsl_test values (9,2,80);  
    insert into zsl_test values (10,2,80);  

    select id,class,score,rank from (  
    select b.id,b.class,b.score,@rownum:=@rownum+1 ,  
    if(@pdept=b.class,@rank:=@rank+1,@rank:=1) as rank,  
    @pdept:=b.class  
    from (  
    select id,class,score from zsl_test order by id   
    ) b ,(select @rownum :=0 , @pdept := null ,@rank:=0) c ) result  
    having rank <3 ;  

Mysql中实现row_number

标签:efault   test   value   row   having   class   number   into   create   

原文地址:http://www.cnblogs.com/thaughtZhao/p/6194575.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!