婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > oracle排名函數的使用方法分享

oracle排名函數的使用方法分享

熱門標簽:七日殺a19.5全地圖標注 N個你智能電銷機器人 地圖標注怎么保存 電渠外呼系統 外呼電話系統用卡嗎 車瑪仕極限運動場所地圖標注 騰訊地圖標注要費用嗎 廣東營銷智能外呼系統商家 高德地圖標注公司名字大全

在oracle中,有rank,dense_rank,row_number,以及分組排名partition。

說明:

rank:排名會出現并列第n名,它之后的會跳過空出的名次,例如:1,2,2,4
dense_rank:排名會出現并列第n名,它之后的名次為n+1,例如:1,2,2,3
row_number:排名采用唯一序號連續值,例如1,2,3,4
partition:將排名限制到某一分組

格式:
 

row_number() over(partition by bb.channel_name order by sum(aa.dk_serv_num) desc nulls last) p1_rank1,
row_number() over(order by sum(aa.dk_serv_num) desc nulls last) rank1,
dense_rank() over(order by nvl(sum(aa.dk_serv_num), 0) desc) rank2,
rank() over(order by sum(aa.dk_serv_num) desc nulls last) rank3

例子:

procedure GetCompetitionRanking(p_UserId in integer, p_CompetitionId in integer, v_cursor out CompetitionCursor)
is
v_startDate date;
v_endDate date;
tmp_startDate varchar2(12);
tmp_endDate varchar2(12);
tmp_date date;
v_sql1 varchar2(2000);
v_sql2 varchar2(2000);
v_where varchar2(1000);

v_comTotal integer;
v_groupTotal integer;
v_comRanking integer;
v_groupRanking integer;
begin
select t.start_date, t.end_date into v_startDate, v_endDate from tbl_competition t where t.competition_id = p_CompetitionId;

tmp_date:= v_endDate+1;
tmp_startDate := to_char(v_startDate, 'yyyy-mm-dd');
tmp_endDate := to_char(tmp_date, 'yyyy-mm-dd');

--group personal total
select count(1) into v_groupTotal from tbl_com_group_user a
where a.com_group_id in
(
select b.com_group_id from tbl_com_group_user b where b.user_id = p_UserId
);

-- Competition personal total
select count(1) into v_comTotal from
(
select a.com_group_id from tbl_com_group a where a.competition_id = p_CompetitionId
) a inner join tbl_com_group_user b on a.com_group_id = b.com_group_id;

--user in competition ranking and group ranking
v_where := 't.DATA_TYPE_ID=1 AND t.STATUS=1 AND
t.DATA_DATE_1 >= TO_DATE('||chr(39)||tmp_startDate||chr(39)||','||chr(39)||'yyyy-mm-dd'||chr(39)||') AND
t.DATA_DATE_1  TO_DATE('||chr(39)||tmp_endDate||chr(39)||','||chr(39)||'yyyy-mm-dd'||chr(39)||') ';

/*select no from
(
select a.USER_ID, dense_rank() over(order by sum(nvl(DATA_NUMBER_2, 0)) desc) no 
from
(
select user_id from tbl_com_group a
left join tbl_com_group_user b on a.com_group_id = b.com_group_id
where a.competition_id = 1
) a left join VM_MASTER_DATA t on a.user_id = t.user_id and t.DATA_TYPE_ID=1 AND t.STATUS=1 AND
t.DATA_DATE_1 >= TO_DATE('2012-10-02','yyyy-mm-dd') AND
t.DATA_DATE_1  TO_DATE('2012-12-01','yyyy-mm-dd') 
group by a.user_id
order by no desc
) where user_id = 165*/

v_sql1 := 'select no from
(
select a.USER_ID, dense_rank() over(order by sum(nvl(DATA_NUMBER_2, 0)) desc) no 
from
(
select user_id from tbl_com_group a
left join tbl_com_group_user b on a.com_group_id = b.com_group_id
where a.competition_id = '||p_CompetitionId||'
) a left join VM_MASTER_DATA t on a.user_id = t.user_id and '|| v_where||'
group by a.user_id
order by no desc 
) where user_id = '||p_UserId;

dbms_output.put_line(v_sql1);
execute immediate v_sql1 into v_comRanking;
dbms_output.put_line('------------------------------');
--dbms_output.put_line(v_comRanking);

/*select no from
( 
select a.USER_ID, dense_rank() over(order by sum(nvl(DATA_NUMBER_2, 0)) desc) no 
from
(
select a.user_id from tbl_com_group_user a
where a.com_group_id in
(
select b.com_group_id from tbl_com_group_user b where b.user_id = 165
)
) a left join VM_MASTER_DATA t on a.user_id = t.user_id and t.DATA_TYPE_ID=1 AND t.STATUS=1 AND
t.DATA_DATE_1 >= TO_DATE('2012-10-02','yyyy-mm-dd') AND
t.DATA_DATE_1  TO_DATE('2012-12-01','yyyy-mm-dd') 
group by a.user_id
order by no desc
)
where user_id=165*/

v_sql2 := 'select no from
(
select a.USER_ID, dense_rank() over(order by sum(nvl(DATA_NUMBER_2, 0)) desc) no
from
(
select a.user_id from tbl_com_group_user a
where a.com_group_id in
(
select b.com_group_id from tbl_com_group_user b where b.user_id = '||p_UserId||'
)
) a left join VM_MASTER_DATA t on a.user_id = t.user_id and '|| v_where||'
group by a.user_id
order by no desc 
) where user_id = '||p_UserId;

dbms_output.put_line(v_sql2);
execute immediate v_sql2 into v_groupRanking;
--dbms_output.put_line('------------------------------');
--dbms_output.put_line(v_groupRanking);

if v_comRanking is null then
v_comRanking := v_comTotal;
end if;

if v_groupRanking is null then
v_groupRanking := v_groupTotal;
end if;

open v_cursor for
select v_comTotal CompetitionPersonalTotal, v_groupTotal UserInGroupPersonTotal, v_comRanking UserInCompRanking, v_groupRanking UserInGroupRanking from dual;

exception
when others then
null;
end;
您可能感興趣的文章:
  • SQL2005 四個排名函數(row_number、rank、dense_rank和ntile)的比較
  • SqlServer 2005的排名函數使用小結
  • SQLSERVER 2005的ROW_NUMBER、RANK、DENSE_RANK的用法
  • Oracle排名函數(Rank)實例詳解
  • 實例講解sql server排名函數DENSE_RANK的用法

標簽:贛州 玉樹 長沙 蘇州 遼寧 大興安嶺 棗莊 來賓

巨人網絡通訊聲明:本文標題《oracle排名函數的使用方法分享》,本文關鍵詞  oracle,排名,函數,的,使用方法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《oracle排名函數的使用方法分享》相關的同類信息!
  • 本頁收集關于oracle排名函數的使用方法分享的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产一区二区在线免费观看| 免费xxxx性欧美18vr| 精品国产成人系列| 欧美区视频在线观看| 欧美综合一区二区三区| 91精品1区2区| 91成人网在线| 日韩一区二区麻豆国产| 久久综合久久久久88| 国产日韩精品一区二区三区 | 精品sm在线观看| 国产亚洲精品bt天堂精选| 精品美女一区二区三区| 国产女人18毛片水真多成人如厕| 国产精品视频免费| 亚洲影院久久精品| 免费三级欧美电影| 国产精品一区二区黑丝| 99久久99久久免费精品蜜臀| 在线欧美日韩精品| 日韩精品中文字幕一区二区三区 | 国产成人在线网站| 成人av网站免费观看| 91麻豆swag| 日韩午夜在线观看视频| 国产亚洲欧美一级| 亚洲黄一区二区三区| 秋霞av亚洲一区二区三| 成人夜色视频网站在线观看| 欧美视频在线一区| 国产亚洲欧美日韩俺去了| 亚洲另类中文字| 青娱乐精品视频| 大尺度一区二区| 日韩精品一区二区三区蜜臀| 国产精品久久久久久久蜜臀| 午夜久久久久久电影| 成a人片国产精品| 91麻豆精品国产91久久久更新时间| 久久久91精品国产一区二区精品| 亚洲精品大片www| 韩日欧美一区二区三区| 在线看日韩精品电影| 26uuu精品一区二区三区四区在线| 亚洲人成精品久久久久久| 精久久久久久久久久久| 欧美色综合影院| 欧美国产一区视频在线观看| 免费观看91视频大全| 91黄色免费看| 国产精品久久久久久久蜜臀| 极品瑜伽女神91| 欧美一区二区福利视频| 亚洲va欧美va人人爽| hitomi一区二区三区精品| 欧美精品一区二区三区蜜桃 | 免费成人美女在线观看.| 91色porny蝌蚪| 国产欧美一区二区精品性| 热久久一区二区| 欧美日韩精品欧美日韩精品一综合| 国产精品毛片无遮挡高清| 成人中文字幕电影| 国产精品全国免费观看高清| 国产99精品国产| 欧美国产激情一区二区三区蜜月| 国内外成人在线| 欧美成人艳星乳罩| 韩国一区二区三区| 亚洲精品在线免费播放| 激情综合色丁香一区二区| 日韩欧美高清一区| 国模少妇一区二区三区| 国产亚洲精品aa| 丁香五精品蜜臀久久久久99网站| 久久精品人人做人人综合| 国产一区二区0| 国产精品伦一区| 99久久精品国产观看| 一区二区免费看| 欧美日韩国产一级二级| 青椒成人免费视频| 欧美精品一区二区三区高清aⅴ| 美女视频黄久久| 久久九九国产精品| av中文一区二区三区| 亚洲一区欧美一区| 欧美不卡在线视频| 国产在线国偷精品免费看| 国产精品久久久一本精品 | wwwwxxxxx欧美| 99久久伊人久久99| 亚洲va韩国va欧美va| 欧美一区二区三区白人| 国产精品系列在线播放| 亚洲视频资源在线| 91精品久久久久久久91蜜桃| 激情综合网av| 亚洲色图欧美在线| 日韩精品最新网址| 91欧美一区二区| 丝袜亚洲另类欧美综合| 精品国产乱码91久久久久久网站| 97久久人人超碰| 精品无人码麻豆乱码1区2区| 中文字幕一区二区三区四区不卡 | 日韩免费观看2025年上映的电影| 豆国产96在线|亚洲| 亚洲大片精品永久免费| 国产免费观看久久| 69av一区二区三区| 不卡大黄网站免费看| 日本中文字幕不卡| 亚洲精品国久久99热| 日韩欧美色电影| 欧美性xxxxxxxx| 91日韩精品一区| 国产成人自拍网| 黄网站免费久久| 三级成人在线视频| 亚洲综合在线五月| 国产精品久久久久久久久免费丝袜 | 国产精品色婷婷| 日韩一区二区精品在线观看| 日本二三区不卡| 国产丶欧美丶日本不卡视频| 午夜国产精品影院在线观看| ●精品国产综合乱码久久久久 | 91久久人澡人人添人人爽欧美| 国产一区二区视频在线| 日本成人在线电影网| 亚洲一区二区三区在线看| 国产精品久久久爽爽爽麻豆色哟哟| 欧美成人性福生活免费看| 欧美日韩中字一区| 一本大道久久精品懂色aⅴ| 国产成人av电影在线观看| 免费观看91视频大全| 午夜精品一区在线观看| 亚洲精品欧美专区| 亚洲另类春色校园小说| 国产精品进线69影院| 国产日产精品一区| 欧美极品美女视频| 国产精品水嫩水嫩| 国产欧美精品一区aⅴ影院| 久久久久久亚洲综合| www国产精品av| 国产欧美日韩亚州综合| 亚洲国产精品成人综合| 亚洲欧洲日韩综合一区二区| 日韩一区在线播放| 一级精品视频在线观看宜春院 | 日韩精品一区第一页| 蜜臀久久99精品久久久久宅男| 男女视频一区二区| 国产一区在线看| 99免费精品视频| 欧美人妇做爰xxxⅹ性高电影| 777奇米成人网| 久久综合久久综合久久综合| 国产日韩欧美不卡| 一区二区三区成人| 三级欧美韩日大片在线看| 久久电影网电视剧免费观看| 激情国产一区二区| 色哟哟在线观看一区二区三区| 欧美少妇xxx| 久久欧美中文字幕| 亚洲精品水蜜桃| 蜜桃精品视频在线| 成人国产电影网| 欧美日韩黄色影视| 国产亚洲成av人在线观看导航| 亚洲欧美日韩国产综合在线| 婷婷成人综合网| 成人黄色一级视频| 欧美一区二区三区在| 国产精品欧美一区喷水| 一区二区三区高清| 国产一区二区三区| 欧美日韩一区 二区 三区 久久精品| 日韩免费一区二区| 亚洲自拍另类综合| 国产精品伊人色| 777午夜精品视频在线播放| 欧美韩日一区二区三区四区| 亚洲专区一二三| 国产盗摄精品一区二区三区在线| 91黄色激情网站| 亚洲国产高清在线观看视频| 亚瑟在线精品视频| 色综合久久中文字幕综合网| 日韩精品一区二区在线| 一个色在线综合| 国产a精品视频| 欧美va在线播放| 同产精品九九九| 日本精品一级二级| 国产精品美女久久久久久|