十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章給大家介紹Oracle中怎么實(shí)現(xiàn)并列排名顯示,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
成都創(chuàng)新互聯(lián)公司專注于徐州企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站設(shè)計(jì),商城系統(tǒng)網(wǎng)站開發(fā)。徐州網(wǎng)站建設(shè)公司,為徐州等地區(qū)提供建站服務(wù)。全流程按需求定制開發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
第一種:dense_rank() over (order by 字段 升序或降序) as 別名 from 表名; 使用別名方便之后過濾條件使用; 排名的時(shí)候并列算同一個(gè)人,如,1,2,2,3 SQL> select ename,job,sal,dense_rank() over(order by sal desc) as rank from emp; ENAME JOB SAL RANK ---------- --------- ---------- ---------- KING PRESIDENT 5000 1 FORD ANALYST 3000 2 SCOTT ANALYST 3000 2 JONES MANAGER 2975 3 BLAKE MANAGER 2850 4 CLARK MANAGER 2450 5 ALLEN SALESMAN 1600 6 TURNER SALESMAN 1500 7 ADAMS CLERK 1400 8 SMITH CLERK 1400 8 MILLER CLERK 1300 9 WARD SALESMAN 1250 10 MARTIN SALESMAN 1250 10 JAMES CLERK 950 11 已選擇14行。 比如限制條件為 排名第二的員工,并列的都顯示出來: SQL> select * from (select ename,job,sal,dense_rank() over(order by sal desc) as rank from emp) where rank =2; ENAME JOB SAL RANK ---------- --------- ---------- ---------- SCOTT ANALYST 3000 2 FORD ANALYST 3000 2 第二種:rank() over (order by 字段名 升序或者降序) as 別名 from 表名; 排名的時(shí)候,并列多少個(gè)人,序號(hào)就算多少個(gè),如:1,2,2,4 SQL> select ename,job,sal,rank() over(order by sal desc) as rank from emp; ENAME JOB SAL RANK ---------- --------- ---------- ---------- KING PRESIDENT 5000 1 FORD ANALYST 3000 2 SCOTT ANALYST 3000 2 JONES MANAGER 2975 4 BLAKE MANAGER 2850 5 CLARK MANAGER 2450 6 ALLEN SALESMAN 1600 7 TURNER SALESMAN 1500 8 ADAMS CLERK 1400 9 SMITH CLERK 1400 9 MILLER CLERK 1300 11 WARD SALESMAN 1250 12 MARTIN SALESMAN 1250 12 JAMES CLERK 950 14 已選擇14行。 第三種:row_number() over (order by 字段名 升序或降序) as 別名 from 表名; 這種就是不分并列,直接按序號(hào)來排名,如:1,2,3,4 SQL> select ename,job,sal,row_number() over(order by sal desc) as rank from emp; ENAME JOB SAL RANK ---------- --------- ---------- ---------- KING PRESIDENT 5000 1 FORD ANALYST 3000 2 SCOTT ANALYST 3000 3 JONES MANAGER 2975 4 BLAKE MANAGER 2850 5 CLARK MANAGER 2450 6 ALLEN SALESMAN 1600 7 TURNER SALESMAN 1500 8 ADAMS CLERK 1400 9 SMITH CLERK 1400 10 MILLER CLERK 1300 11 WARD SALESMAN 1250 12 MARTIN SALESMAN 1250 13 JAMES CLERK 950 14 已選擇14行。
關(guān)于Oracle中怎么實(shí)現(xiàn)并列排名顯示就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。