Mysql sorting to get ranking example code

Mysql sorting to get ranking example code

The code looks like this:

SELECT @i:=@i+1 rowNum,
if(@total=t.s_score,@rank,@rank:=@i) rank,@total:=t.s_score,
t.*
from(
select t1.* ,t2.s_score from student t1 LEFT JOIN score t2 on t1.s_id=t2.s_id and t2.c_id="01" ORDER BY t2.s_score desc
)t,(select @i:=0,@rank:=0,@total:=null) s ;
SELECT @i:=@i+1 rowNum,
if(@total=t.s_score,@rank,@rank:=@rank+1) rank,@total:=t.s_score,
t.*
from(
select t1.* ,t2.s_score from student t1 LEFT JOIN score t2 on t1.s_id=t2.s_id and t2.c_id="01" ORDER BY t2.s_score desc
)t,(select @i:=0,@rank:=0,@total:=null) s ;

Mysql gets the ranking after the grades are sorted

In fact, it outputs the row number after mysql sorting

RT: Get the ranking of a single user's score among all users' scores

It can be divided into two steps:

1. Find all users and their performance rankings

select id,maxScore,(@rowNum:=@rowNum+1) as rowNo 
from t_user, 
(select (@rowNum :=0) ) b 
order by t_user.maxScore desc

2. Find out the ranking of a user among all users' scores

select u.rowNo from ( 
select id,(@rowNum:=@rowNum+1) as rowNo 
from t_user, 
(select (@rowNum :=0) ) b 
order by t_user.maxScore desc ) u where u.id="2015091810371700001";

Summarize

The above is the Mysql sorting and ranking acquisition introduced by the editor. I hope it will be helpful to everyone. If you have any questions, please leave me a message and the editor will reply to you in time. I would also like to thank everyone for their support of the 123WORDPRESS.COM website!

You may also be interested in:
  • MYSQL implements ranking and querying specified user ranking function (parallel ranking function) example code
  • MySQL page access statistics and rankings
  • How to add ranking to custom field query results in MySQL
  • MySQL grouping to get the first few records in each group (ranking) with research on group by and order by
  • Summarize several common ranking problems in MySQL

<<:  How to use Webstorm and Chrome to debug Vue projects

>>:  How to deal with the xfs_vm_releasepage warning problem reported by the Linux system

Recommend

What are the benefits of using B+ tree as index structure in MySQL?

Preface In MySQL, both Innodb and MyIsam use B+ t...

mysql is not an internal command error solution

The error "mysql is not an internal command&...

Implementation of vue-nuxt login authentication

Table of contents introduce Link start Continue t...

How to connect to a remote docker server with a certificate

Table of contents 1. Use scripts to encrypt TLS f...

JavaScript function encapsulates random color verification code (complete code)

An n-digit verification code consisting of number...

Web page text design should be like smart girls wearing clothes

<br />"There are no ugly women in the w...

Vue: Detailed explanation of memory leaks

What is a memory leak? A memory leak means that a...

A brief discussion on VUE uni-app template syntax

1.v-bind (abbreviation:) To use data variables de...

Some properties in CSS are preceded by "*" or "_".

Some properties in CSS are preceded by "*&qu...

Getting Started Tutorial on Animating SVG Path Strokes Using CSS3

Without relying on JavaScript, pure CSS is used t...

MySQL sorting principles and case analysis

Preface Sorting is a basic function in databases,...

MySQL Billions of Data Import, Export and Migration Notes

I have been taking a lot of MySQL notes recently,...