首页 Oracle Oracle排名函数(Rank)实例详解

Oracle排名函数(Rank)实例详解

这篇文章主要介绍了Oracle排名函数(Rank)实例详解,需要的朋友可以参考下

–已知:两种排名方式(分区和不分区):使用和不使用partition

–两种计算方式(连续,不连续),对应函数:dense_rank,rank

·查询原始数据:学号,姓名,科目名,成绩

select

*

from

t_score

S_ID S_NAME SUB_NAME SCORE ·查询各学生科目为Oracle排名(简单排名)

select

sc.s_id,sc.s_name,sub_name,sc.score,

rank() over

(

order

by

score

desc

) 名次

from

t_score sc

where

sub_name=’Oracle’

S_ID S_NAME SUB_NAME SCORE 名次 对比:rank()与dense_rank():非连续排名与连续排名(都是简单排名)

select

sc.s_id,

dense_rank() over

(

order

by

score

desc

) 名次

from

t_score sc

where

sub_name=’Oracle’

S_ID S_NAME SUB_NAME SCORE 名次 ·查询各学生各科排名(分区排名)

select

sc.s_id,
rank() over
(

partition

by

sub_name

order

by

score

desc

) 名次

from

t_score sc

S_ID S_NAME SUB_NAME SCORE 名次 ·查询各科前2名(分区排名)

本文来自网络,不代表青岛站长网立场。转载请注明出处: https://www.0532zz.com/html/shujuku/oracle/20210123/16636.html
上一篇
下一篇

作者: dawei

【声明】:青岛站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

【免责声明】本站内容转载自互联网,其发布内容言论不代表本站观点,如果其链接、内容的侵犯您的权益,烦请提交相关链接至邮箱xwei067@foxmail.com我们将及时予以处理。

Copygight © 2016-2023 https://www.0532zz.com All Rights Reserved.青岛站长网

站长:xwei067#foxmail.com(请把#换成@)