最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
MYSQL怎么實(shí)現(xiàn)分組排序功能

這篇文章主要講解了“MySQL怎么實(shí)現(xiàn)分組排序功能”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“MYSQL怎么實(shí)現(xiàn)分組排序功能”吧!

創(chuàng)新互聯(lián)專注于東阿企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站建設(shè)。東阿網(wǎng)站建設(shè)公司,為東阿等地區(qū)提供建站服務(wù)。全流程定制網(wǎng)站制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

由于MYSQL沒有提供類似ORACLE中OVER()這樣豐富的分析函數(shù). 所以在MYSQL里需要實(shí)現(xiàn)這樣的功能,我們只能用一些靈活的辦法:

1.首先我們來創(chuàng)建實(shí)例數(shù)據(jù):

drop table if exists heyf_t10;
create table heyf_t10 (empid int ,deptid int ,salary decimal(10,2) );

insert into heyf_t10 values
(1,10,5500.00),
(2,10,4500.00),
(3,20,1900.00),
(4,20,4800.00),
(5,40,6500.00),
(6,40,14500.00),
(7,40,44500.00),
(8,50,6500.00),
(9,50,7500.00);

2. 確定需求: 根據(jù)部門來分組,顯示各員工在部門里按薪水排名名次.

顯示結(jié)果預(yù)期如下:

+-------+--------+----------+------+
| empid | deptid | salary   | rank |
+-------+--------+----------+------+
|     1 |     10 |  5500.00 |    1 |
|     2 |     10 |  4500.00 |    2 |
|     4 |     20 |  4800.00 |    1 |
|     3 |     20 |  1900.00 |    2 |
|     7 |     40 | 44500.00 |    1 |
|     6 |     40 | 14500.00 |    2 |
|     5 |     40 |  6500.00 |    3 |
|     9 |     50 |  7500.00 |    1 |
|     8 |     50 |  6500.00 |    2 |
+-------+--------+----------+------+


3. SQL 實(shí)現(xiàn)

select empid,deptid,salary,rank from (
select heyf_tmp.empid,heyf_tmp.deptid,heyf_tmp.salary,@rownum:=@rownum+1 ,
if(@pdept=heyf_tmp.deptid,@rank:=@rank+1,@rank:=1) as rank,
@pdept:=heyf_tmp.deptid
from (
select empid,deptid,salary from heyf_t10 order by deptid asc ,salary desc
) heyf_tmp ,(select @rownum :=0 , @pdept := null ,@rank:=0) a ) result
;

4. 結(jié)果演示

mysql> select empid,deptid,salary,rank from (
   -> select heyf_tmp.empid,heyf_tmp.deptid,heyf_tmp.salary,@rownum:=@rownum+1 ,
   -> if(@pdept=heyf_tmp.deptid,@rank:=@rank+1,@rank:=1) as rank,
   -> @pdept:=heyf_tmp.deptid
   -> from (
   -> select empid,deptid,salary from heyf_t10 order by deptid asc ,salary desc
   -> ) heyf_tmp ,(select @rownum :=0 , @pdept := null ,@rank:=0) a ) result
   ->  ;
+-------+--------+----------+------+
| empid | deptid | salary   | rank |
+-------+--------+----------+------+
|     1 |     10 |  5500.00 |    1 |
|     2 |     10 |  4500.00 |    2 |
|     4 |     20 |  4800.00 |    1 |
|     3 |     20 |  1900.00 |    2 |
|     7 |     40 | 44500.00 |    1 |
|     6 |     40 | 14500.00 |    2 |
|     5 |     40 |  6500.00 |    3 |
|     9 |     50 |  7500.00 |    1 |
|     8 |     50 |  6500.00 |    2 |
+-------+--------+----------+------+
9 rows in set (0.00 sec)

感謝各位的閱讀,以上就是“MYSQL怎么實(shí)現(xiàn)分組排序功能”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)MYSQL怎么實(shí)現(xiàn)分組排序功能這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!


文章題目:MYSQL怎么實(shí)現(xiàn)分組排序功能
標(biāo)題鏈接:http://fisionsoft.com.cn/article/jocspp.html