排名 sql

简介:

结构为
user scores
1      80
2     7
3     99
4     58
..

比如我想计算user
=4在此表中的排名应该如何做?

SELECT COUNT* ) FROM user_test WHERE scores >= ( SELECT scores FROM user_test 
WHERE user =4 ) 


--参数说明:
--
sc 表名
--
name 人名
--
mark 分数
--
ord 名次


1、并列,有空档,名次是不连续的(有两个第二名,接下来的就是第四名)。
update sc set ord=(select count(*)+1 from sc B where B.mark>sc.mark)
说明:其实就是求出分数比他多的人数,再加上1。


2、并列,无空档,名次总是连续的
update sc set ord=(select count(*from (select distinct mark from sc) as distmark where distmark.mark >=sc.mark)
说明:
select distinct mark from sc 是求出不重复的分数,然后看你的分数排在哪个位置。

 

--1. 名次生成方式1,Score重复时合并名次
SELECT *,Place=(SELECT COUNT(DISTINCT Score) FROM tb WHERE Score>=a.Score)
FROM tb a
ORDER BY Place
/*--结果
Name       Score        Place 
---------------- ----------------- ----------- 
aa         99.00        1
ee         78.00        2
gg         78.00        2
dd         77.00        3
ff         76.00        4
bb         56.00        5
cc         56.00        5
ff         50.00        6
--
*/

--2. 名次生成方式2,Score重复时保留名次空缺
SELECT *,Place=(SELECT COUNT(Score) FROM tb WHERE Score>a.Score)+1
FROM tb a
ORDER BY Place
/*--结果
Name       Score        Place 
--------------- ----------------- ----------- 
aa         99.00        1
ee         78.00        2
gg         78.00        2
dd         77.00        4
ff         76.00        5
bb         56.00        6
cc         56.00        6
ff         50.00        8
--
*/

 

    本文转自曾祥展博客园博客,原文链接:http://www.cnblogs.com/zengxiangzhan/archive/2009/09/23/1572290.html,如需转载请自行联系原作者


相关文章
|
6月前
|
SQL
leetcode-SQL-1407. 排名靠前的旅行者
leetcode-SQL-1407. 排名靠前的旅行者
52 1
|
6月前
|
SQL 分布式计算 NoSQL
【SQL 审核查询平台】Archery使用介绍
【SQL 审核查询平台】Archery使用介绍
365 0
【SQL 审核查询平台】Archery使用介绍
|
3月前
|
SQL 缓存 关系型数据库
SQL如何优化查询?
【8月更文挑战第1天】SQL如何优化查询?
49 1
|
6月前
|
SQL 数据库
三、SQL的基础查询
三、SQL的基础查询
52 0
|
6月前
|
SQL 人工智能 大数据
每天一道大厂SQL题【Day01】访问量统计
每天一道大厂SQL题【Day01】访问量统计
87 0
|
SQL 数据库
SQL处理排行榜问题
SQL处理排行榜问题
|
SQL 开发框架 .NET
sql 不同where下的统计
sql 不同where下的统计
76 0
SQL Server成绩统计分析中的排名问题介绍
成绩分析中经常遇到的问题就是排名问题了,今天给大家介绍一下SQL Server排名中经常用到的ROW_NUMBER(),RANK(),DENSE_RANK(),NTILE()这四个好兄弟。
SQL Server成绩统计分析中的排名问题介绍
|
SQL 关系型数据库 MySQL
教你用SQL实现统计排名
在某些应用场景中,我们经常会遇到一些排名的问题,比如按成绩或年龄排名。排名也有多种排名方式,如直接排名、分组排名,排名有间隔或排名无间隔等等,这篇文章将总结几种MySQL中常见的排名问题。
755 0