欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL實現(xiàn)LeetCode(178.分數(shù)排行)

 更新時間:2021年08月03日 15:32:34   作者:Grandyang  
這篇文章主要介紹了SQL實現(xiàn)LeetCode(178.分數(shù)排行),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下

[LeetCode] 178.Rank Scores 分數(shù)排行

Write a SQL query to rank scores. If there is a tie between two scores, both should have the same ranking. Note that after a tie, the next ranking number should be the next consecutive integer value. In other words, there should be no "holes" between ranks.

+----+-------+
| Id | Score |
+----+-------+
| 1  | 3.50  |
| 2  | 3.65  |
| 3  | 4.00  |
| 4  | 3.85  |
| 5  | 4.00  |
| 6  | 3.65  |
+----+-------+

For example, given the above Scores table, your query should generate the following report (order by highest score):

+-------+------+
| Score | Rank |
+-------+------+
| 4.00  | 1    |
| 4.00  | 1    |
| 3.85  | 2    |
| 3.65  | 3    |
| 3.65  | 3    |
| 3.50  | 4    |
+-------+------+

這道題給了我們一個分數(shù)表,讓我們給分數(shù)排序,要求是相同的分數(shù)在相同的名次,下一個分數(shù)在相連的下一個名次,中間不能有空缺數(shù)字,這道題我是完全照著史蒂芬大神的帖子來寫的,膜拜大神中...大神總結(jié)了四種方法,那么我們一個一個的來膜拜學(xué)習(xí),首先看第一種解法,解題的思路是對于每一個分數(shù),找出表中有多少個大于或等于該分數(shù)的不同的分數(shù),然后按降序排列即可,參見代碼如下:

解法一:

SELECT Score, 
(SELECT COUNT(DISTINCT Score) FROM Scores WHERE Score >= s.Score) Rank 
FROM Scores s ORDER BY Score DESC;

跟上面的解法思想相同,就是寫法上略有不同:

解法二:

SELECT Score,
(SELECT COUNT(*) FROM (SELECT DISTINCT Score s FROM Scores) t WHERE s >= Score) Rank
FROM Scores ORDER BY Score DESC;

下面這種解法使用了內(nèi)交,Join是Inner Join的簡寫形式,自己和自己內(nèi)交,條件是右表的分數(shù)大于等于左表,然后群組起來根據(jù)分數(shù)的降序排列,十分巧妙的解法:

解法三:

SELECT s.Score, COUNT(DISTINCT t.Score) Rank
FROM Scores s JOIN Scores t ON s.Score <= t.Score
GROUP BY s.Id ORDER BY s.Score DESC;

下面這種解法跟上面三種的畫風就不太一樣了,這里用了兩個變量,變量使用時其前面需要加@,這里的:= 是賦值的意思,如果前面有Set關(guān)鍵字,則可以直接用=號來賦值,如果沒有,則必須要使用:=來賦值,兩個變量rank和pre,其中rank表示當前的排名,pre表示之前的分數(shù),下面代碼中的<>表示不等于,如果左右兩邊不相等,則返回true或1,若相等,則返回false或0。初始化rank為0,pre為-1,然后按降序排列分數(shù),對于分數(shù)4來說,pre賦為4,和之前的pre值-1不同,所以rank要加1,那么分數(shù)4的rank就為1,下面一個分數(shù)還是4,那么pre賦值為4和之前的4相同,所以rank要加0,所以這個分數(shù)4的rank也是1,以此類推就可以計算出所有分數(shù)的rank了。

解法四:

SELECT Score,
@rank := @rank + (@pre <> (@pre := Score)) Rank
FROM Scores, (SELECT @rank := 0, @pre := -1) INIT 
ORDER BY Score DESC;

參考資料:

https://leetcode.com/discuss/40116/simple-short-fast

到此這篇關(guān)于SQL實現(xiàn)LeetCode(178.分數(shù)排行)的文章就介紹到這了,更多相關(guān)SQL實現(xiàn)分數(shù)排行內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mysql查詢語句優(yōu)化技巧

    Mysql查詢語句優(yōu)化技巧

    這篇文章主要介紹了Mysql查詢語句優(yōu)化技巧的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • mysql alter table 修改表命令詳細介紹

    mysql alter table 修改表命令詳細介紹

    MYSQL ALTER TABLE命令用于修改表結(jié)構(gòu),例如添加/修改/刪除字段、索引、主鍵等等,本文章通過實例向大家介紹MYSQL ALTER TABLE語句的使用方法,需要的朋友可以參考一下。
    2016-10-10
  • MySQL Antelope和Barracuda的區(qū)別分析

    MySQL Antelope和Barracuda的區(qū)別分析

    這篇文章主要介紹了MySQL Antelope和Barracuda的區(qū)別分析,Antelope和Barracude都是一種文件格式,需要的朋友可以參考下
    2014-07-07
  • Linux(CentOS7)安裝MySQL8全過程

    Linux(CentOS7)安裝MySQL8全過程

    這篇文章主要介紹了Linux(CentOS7)安裝MySQL8全過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • mysql之DML的select分組排序方式

    mysql之DML的select分組排序方式

    在此教程中,我們詳細介紹如何創(chuàng)建員工(employee)和部門(department)數(shù)據(jù)庫表,并展示了如何通過SQL語句進行數(shù)據(jù)插入、刪除和查詢,首先,創(chuàng)建了部門表并自動設(shè)置部門編號起始值為1001,接著創(chuàng)建員工表并定義了各字段,我們還設(shè)置了外鍵關(guān)聯(lián)兩表
    2024-09-09
  • Windows server 2008 r2下MySQL5.7.17 winx64安裝版配置方法圖文教程

    Windows server 2008 r2下MySQL5.7.17 winx64安裝版配置方法圖文教程

    這篇文章主要為大家詳細介紹了Windows server 2008 r2下MySQL5.7.17 winx64安裝版配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Linux下MySQL5.7.18 yum方式從卸載到安裝過程圖解

    Linux下MySQL5.7.18 yum方式從卸載到安裝過程圖解

    這篇文章主要介紹了Linux下MySQL5.7.18 yum方式從卸載到安裝過程圖解,需要的朋友可以參考下
    2017-06-06
  • MySQL分區(qū)表實現(xiàn)按月份歸類

    MySQL分區(qū)表實現(xiàn)按月份歸類

    mysql 單表數(shù)據(jù)量達到千萬、億級,可以通過分表與表分區(qū)提升服務(wù)性能。本文主要介紹了MySQL分區(qū)表實現(xiàn)按月份歸類,感興趣的可以了解一下
    2021-10-10
  • mysql中的int(5)到底有是多長

    mysql中的int(5)到底有是多長

    這篇文章主要介紹了mysql中的int(5)到底有是多長,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • MYSQL使用inner join 進行 查詢/刪除/修改示例

    MYSQL使用inner join 進行 查詢/刪除/修改示例

    本文為大家介紹下使用inner join 進行查詢/刪除/修改,具體實現(xiàn)如下,學(xué)習(xí)mysql的朋也可以學(xué)習(xí)下,希望對大家有所幫助
    2013-07-07

最新評論