MySQL中row_number的實現(xiàn)過程
一 、背景
一般在數(shù)據(jù)倉庫環(huán)境中,我們可以很方便的使用row_number函數(shù)根據(jù)某個維度來對數(shù)據(jù)進行分組,實現(xiàn)每個組內數(shù)據(jù)編號排序的效果。如下圖所示,該圖是在mysql環(huán)境中生成的效果圖,這里以lcid進行的分組,num等價于row_number函數(shù)實現(xiàn)的效果:

二、實現(xiàn)過程
1.設置mysql變量
設置兩個變量
set @row_number:=0; --根據(jù)lcid_no的判斷結果生成row_number序號 set @lcid_no:= 0; --用于獲取每行l(wèi)cid列數(shù)據(jù),然后與前面一行的lcid數(shù)據(jù)進行對比,若相同則自增1,否則為1
2.使用case when
SELECT @row_number:=CASE
WHEN @lcid_no = s.lcid THEN @row_number + 1
ELSE 1
END AS num,
@lcid_no:=s.lcid AS lcid,
s.lcid
FROM r_qcloud_approval_fh_d s,(select @orw_number:=0,@lcid_no:=0) t
ORDER BY s.lcid;
3.過程分析
若存在多條相同數(shù)據(jù)情形
1)初始條件下,游標指向第一條數(shù)據(jù),此時lcid_no = 0,lcid_no 不等于lcid,故row_number = 1
2)游標指向第二條數(shù)據(jù),lcid_no = 上一條數(shù)據(jù)的lcid,因上一條數(shù)據(jù)的lcid = 當前行l(wèi)cid,因此row_number =2
無重復數(shù)據(jù)情形
1)初始條件下,游標指向第一條數(shù)據(jù),此時lcid_no = 0,lcid_no 不等于lcid,故row_number = 1
三、使用場景
在mysql這種關系型數(shù)據(jù)庫中,沒有row_number函數(shù)的情況下使用
到此這篇關于MySQL中row_number的實現(xiàn)過程的文章就介紹到這了,更多相關MySQL中row_number內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Windows10系統(tǒng)下Mysql8.0.13忘記root密碼的操作方法
這篇文章主要給大家介紹了關于Windows10系統(tǒng)下Mysql8.0.13忘記root密碼的操作方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01
mysql啟動報錯Failed?to?start?LSB:start?and?stop?MySQL的問題解決
本文主要介紹了mysql啟動報錯Failed?to?start?LSB:start?and?stop?MySQL的問題解決,具有一定的參考價值,感興趣的可以了解一下2023-10-10
MySQL中使用JSON存儲數(shù)據(jù)的實現(xiàn)示例
本文主要介紹了MySQL中使用JSON存儲數(shù)據(jù)的實現(xiàn)示例,我們可以在MySQL中直接存儲、查詢和操作JSON數(shù)據(jù),具有一定的參考價值,感興趣的可以了解一下2023-09-09

