mysql 分組top_MySQL:如何查詢出每個分組中的 top n 條記錄?

問題描述

27fa3919e706153a4f8017b8a10111d0.png

需求:

查詢出每月 order_amount(訂單金額) 排行前3的記錄。

例如對于2019-02,查詢結果中就應該是這3條:

4c7a520489cdc19be68d77f27dac783e.png

解決方法

MySQL 5.7 和 MySQL 8.0 有不同的處理方法。

1. MySQL 5.7

我們先寫一個查詢語句。

根據 order_date 中的年、月,和order_amount進行降序排列。

然后,添加一個新列:order_amount(本條記錄在本月中的名次)。

443671fcbb325b817dc7fa0c7a018095.png

執行結果:

4d581dadf9781fda5311f290dcf28ac0.png

可以看到,根據年、月、訂單金額排序了,還多了一列order_rank,顯示出了本條記錄在本月的訂單金額排名情況。

上面SQL中比較個性的是這部分:

06acbd3a15833ecbe6446bbf05a6ed79.png

@current_month和@order_rank 是我們自定義的變量。

使用 := 可以動態創建一個變量,而不需要使用 set 命令。

2e6d467199bb27a984d531b862b83f16.png

這句的含義:

取得order_date中的月份值,賦值給current_month,這樣就可以跟蹤每個月份。

78673baab5c9a6e00632b4d2869cecdb.png

這句的含義:

比較 current_month 和本條記錄中的月份,如果一樣,order_rank 自增1,否則,置為1。

注意,@current_month 是在 @order_rank 的后面,例如執行到這條記錄時:

a6bae34b518f8cb0d38160a65b0e5c9d.png

if 判斷中,MONTH(order_date) 值為 2,而 current_month 值為 1,還是上條記錄設置的。

接下來,把上面的SQL語句作為一個子查詢,然后使用一個 where 條件就可以輕松拿到每組的 top 3。

最終語句:

dba35a46fa2e73bcc94b6dfd17c00b46.png

執行結果:

677954c0e325782020e7354396dac292.png

2. MySQL 8

MySQL 8 引入了一個 rank() 函數,可以更簡便的實現排行的功能。

27e181216fc2302e9b36167f635b9967.png

執行結果:

f6b58e89723deecd12e69c51591d0d34.png

效果和 5.7 中的方法是一致的。

我們看下語句中的 rank() 方法:

a56818be4ad488c9d03235a1bb06525a.png

PARTITION BY 是指定分區依據,這里是根據訂單的年、月進行分區。

ORDER BY 指定了分區內的排序依據,這里是根據訂單的 年、月、金額 進行降序排列。

這樣就會自動計算出排行數值。

需要注意的是,這個地方和 5.7 的方法不一樣:

87c67dfd7f3d3d54e934f93cafe4e95a.png

就是參與排序的幾個值一樣的時候,rank 值是一樣的。

最終的SQL語句:

49914b3c19f8ac0531b3672a1946e143.png

翻譯整理自:

如果您有興趣實踐一下,在公眾號“性能與架構”中發送消息:200106,會回復實踐筆記的下載地址,包含建表語句、測試數據、MySQL5.7和8.0的這2個查詢語句。

推薦閱讀:

74495d12c8c437b2e5b4bf13480e3b2d.png

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/372895.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/372895.shtml
英文地址,請注明出處:http://en.pswp.cn/news/372895.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ACM第四站————最小生成樹(普里姆算法)

對于一個帶權的無向連通圖,其每個生成樹所有邊上的權值之和可能不同,我們把所有邊上權值之和最小的生成樹稱為圖的最小生成樹。 普里姆算法是以其中某一頂點為起點,逐步尋找各個頂點上最小權值的邊來構建最小生成樹。 其中運用到了回溯&#…

利用jenkins的api來完成相關工作流程的自動化

[本文出自天外歸云的博客園] 背景 1. 實際工作中涉及到安卓客戶端方面的測試,外推或運營部門經常會有很多的渠道,而每個渠道都對應著一個app的下載包,這些渠道都記錄在安卓項目下的一個渠道列表文件中。外推或運營部門經常會有新的渠道產生&a…

擁有成本分析:Oracle WebLogic Server與JBoss

Crimson Consulting Group 撰寫的非常有趣的白皮書 ,比較了Weblogic和JBoss之間的擁有成本 。 盡管JBoss是免費的,但該白皮書卻嚴肅地宣稱,從長遠來看,Weblogic更便宜。 盡管此研究是由Oracle贊助的,但它看起來非常嚴肅…

mysql limit 分頁 0_Mysql分頁之limit用法與limit優化

Mysql limit分頁語句用法與Oracle和MS SqlServer相比,mysql的分頁方法簡單的讓人想哭。--語法:SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset--舉例:select * from table limit 5; --返回前5行select * from table limit 0…

與硒的集成測試

總覽 我已經使用了一段時間,遇到了一些似乎可以使生活更輕松的事情。 我以為可以將其作為教程分享,所以我將向您介紹這些部分: 使用Maven設置Web項目,配置Selenium以在CI上作為集成測試運行 尋找使用“頁面對象”為網站中的頁面…

linux每天一小步---sed命令詳解

1 命令功能 sed是一個相當強大的文件處理編輯工具,sed用來替換,刪除,更新文件中的內容。sed以文本行為單位進行處理,一次處理一行內容。首先sed吧當前處理的行存儲在臨時的緩沖區中(稱為模式空間pattern space&#xf…

mysql trace工具_100% 展示 MySQL 語句執行的神器-Optimizer Trace

在上一篇文章《用Explain 命令分析 MySQL 的 SQL 執行》中,我們講解了 Explain 命令的詳細使用。但是它只能展示 SQL 語句的執行計劃,無法展示為什么一些其他的執行計劃未被選擇,比如說明明有索引,但是為什么查詢時未使用索引等。…

MOXy作為您的JAX-RS JSON提供程序–服務器端

在以前的系列文章中,我介紹了如何利用EclipseLink JAXB(MOXy)創建RESTful數據訪問服務。 在本文中,我將介紹在服務器端利用MOXy的新JSON綁定添加對基于JAXB映射的JSON消息的支持有多么容易。 MOXy作為您的JAX-RS JSON提供程序–服…

006_過濾器

過濾器 過濾器(Filter)把附加邏輯注入到MVC框的請求處理,實現了交叉關注。所謂交叉關注(Cross-Cutting Concerns),是指可以用于整個應用程序,而又不適合放置在某個局部位置的功能,否…

Android_項目文件結構目錄分析

android項目文件結構目錄分析 在此我們新建了一個helloworld的項目,先看一些目錄結構: 這么多的文件夾和文件中,我們重點關注是res目錄、src目錄、AndroidManifest.xml文件: 一、res目錄主要是用來存放android項目的各種資源文件&…

實體 聯系 模型mysql_數據庫系統概念讀書筆記――實體-聯系模型_MySQL

bitsCN.com數據庫系統概念讀書筆記——實體-聯系模型前言為了重新回顧我寫的消息系統架構,我需要重新讀一下數據庫系統概念的前三章,這里簡單的做一個筆記,方便自己回顧基本概念實體-聯系(E-R)數據模型基于對現實世界的這樣一種認識&#xff…

使用Twitter Bootstrap,WebSocket,Akka和OpenLayers玩(2.0)

原始帖子可以在ekito網站上找到。 對于我們的一位客戶,我們需要顯示一張具有實時更新的車輛位置的地圖。 因此,我開始使用Play制作原型! 框架及其最新發布的版本2.0,使用Java API。 我從Play的網絡聊天室開始! 2.0個樣…

同步時間

同步時間 [rootlocalhost 03]# ntpdate 0.centos.pool.ntp.org 轉載于:https://www.cnblogs.com/cglWorkBook/p/5556920.html

mysql 5.6.23免安裝_mysql5.6.23免安裝配置

1.官網下載,并解壓2.環境變量,path下,追加mysql的bin路徑D:\Program Files\mysql\bin;3.mysql目錄下的my-default.ini重命名為my.ini,并添加下面的代碼basedirD:/Program Files/mysql #mysql路徑datadirD:/Program Files/mysql/d…

在Intellij IDEA中運行Vaadin應用

在本文中,我將向您展示如何使用Intellij IDEA運行vaadin應用程序。 Vaadin提供了一些用于Eclipse和Netbeans的插件。 但是對于Intellij IDEA來說,還沒有插件。 但是部署vaadin應用程序比其他兩個IDE容易。 這是您要遵循的步驟。 1.首先創建一個新項目&am…

mysql主從數據庫

Mysql主從配置,實現讀寫分離 大型網站為了軟解大量的并發訪問,除了在網站實現分布式負載均衡,遠遠不夠。到了數據業務層、數據訪問層,如果還是傳統的數據結構,或者只是單單靠一臺服務器扛,如此多的數據庫連…

安裝openstack時遇到的錯誤

學習opensatck的第一步是安裝DevStack來進行本機操作 1. 下面命令沒有權限,解決辦法:切換到root用戶下執行sudo -s echo "stack ALL(ALL) NOPASSWD: ALL" >> /etc/sudoers2. 執行下面命令提示沒有git,解決辦法:su…

Java EE 6示例– Galleria –第3部分

關于Galleria示例的先前文章( 第1 部分 | 第2部分 | 第3部分 | 第4部分 )指導您完成基礎知識以及對GlassFish和WebLogic的初始部署。 從今天開始,我嘗試在其中添加一些企業級功能,因為我發現他們在自己的項目中提出了很多要求。 我…

在 Windows 上測試 Redis Cluster的集群填坑筆記

redis 集群實現的原理請參考http://www.tuicool.com/articles/VvIZje集群環境至少需要3個節點。推薦使用6個節點配置,即3個主節點,3個從節點。新建6個文件夾 分別是 7000/7001/7002/7003/7004/7005將redis.windows.conf 復制一份然后修改配置文件中的下面…