91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mysql數據分組排名實現的示例分析

發布時間:2021-10-31 16:49:59 來源:億速云 閱讀:586 作者:小新 欄目:開發技術

Mysql數據分組排名實現的示例分析,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

    1.數據源

    Mysql數據分組排名實現的示例分析

    2.數據整體排名

    1)普通排名

    從1開始,按照順序一次往下排(相同的值也是不同的排名)。

    set @rank =0;
    select 
    	city ,
    	score, 
    	@rank := @rank+1 rank 
    from cs 
    order by score desc;

    結果如下:

    Mysql數據分組排名實現的示例分析

    2)并列排名

    相同的值是相同的排名(但是不留空位)。

    set @rank=0,@price=null;
    select cs.* ,
     case when @price = score then @rank 
     when @price := score then @rank := @rank+1 end rank  
     from cs order by score desc;
     -- 當查詢的score 值 = @price時,輸出@rank,
     -- 當不等時,將score值賦給@price ,并輸出@rank := @rank+1
     
    -- 或者
    set @rank=0,@price=null;
    select 
    	a.city,a.score,a.rank 
    from 
    (select cs.*,
    	@rank := if(@p=score,@rank,@rank+1) rank,
    	@p := score
    from cs 
    order by score desc) a;

    結果如下:

    Mysql數據分組排名實現的示例分析

    3)并列排名

    相同的值是相同的排名(但是留空位)。

    set @rank=0,@price=null, @z=1;
    select 
    	a.city,a.score,a.rank 
    from 
    (select 
    	cs.*,
    	@rank := if(@p=score,@rank,@z) rank,
    	@p := score,@z :=@z+1
    from cs 
    order by score desc) a;

    結果如下:

    Mysql數據分組排名實現的示例分析

    3.數據分組后組內排名

    1)分組普通排名

    從1開始,按照順序一次往下排(相同的值也是不同的排名)。

    set @rank=0,@c=null;
    select 
    	cs.city,cs.score,
    	@rank := if(@c = city,@rank+1,1) rank,
    	@c := city
    from cs 
    order by cs.city,cs.score;

    結果如下:

    Mysql數據分組排名實現的示例分析

    2)分組后并列排名

    組內相同數值排名相同,不占空位。

    set @rank=0,@c=null,@s=null;
    select 
    	cs.city,cs.score,
    	@rank := if(@c=city,if(@s=score,@rank,@rank+1),1) rank ,
    	@c := city,
    	@s :=score 
    from cs 
    order by cs.city,cs.score;

    結果如下:

    Mysql數據分組排名實現的示例分析

    3)分組后并列排名

    組內相同數值排名相同,需要占空位。

    set @rank=0,@c=null,@s=null;
    select 
    	cs.city,cs.score,
    	@rank := if(@c=city,if(@s=score,@rank,@rank+1),1) rank ,
    	@c := city,
    	@s :=score 
    from cs 
    order by cs.city,cs.score;

    結果如下:

    Mysql數據分組排名實現的示例分析

    4.分組后取各組的前兩名

    ① 方法一:按照分組排名的三種方式,然后限定排名的值

    set @rank=0,@z=0,@c=null,@s=null;
    select a.city,a.score,a.rank from 
    (select 
    	cs.city city,cs.score score,
    	@z := if(@c=city,@z+1,1),
    	@rank := if(@c=city,if(@s=score,@rank,@z),1) rank,
    	@c := city,
    	@s :=score 
    from cs 
    order by cs.city,cs.score desc) a
    where a.rank<=2;

    結果如下:

    Mysql數據分組排名實現的示例分析

    ② 內部查詢

    SELECT * FROM cs c
    WHERE (
        SELECT count(*) FROM cs
        WHERE c.city=cs.city AND c.score<cs.score )<2
    ORDER BY city,score DESC;

    結果如下:

    Mysql數據分組排名實現的示例分析

    上述代碼的執行原理如下圖:

    Mysql數據分組排名實現的示例分析

    看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    富民县| 罗定市| 丹棱县| 镶黄旗| 耒阳市| 寿宁县| 和平区| 府谷县| 平谷区| 仁寿县| 屏东市| 江北区| 保德县| 木里| 桐柏县| 铁力市| 天水市| 临夏市| 辽宁省| 株洲县| 抚松县| 谢通门县| 沽源县| 南安市| 无棣县| 胶南市| 井研县| 开平市| 怀集县| 始兴县| 龙南县| 娄底市| 鹤壁市| 太湖县| 九台市| 彝良县| 延津县| 沁水县| 渭南市| 宝山区| 普格县|