MySQL實現SQL Server排名函數

来源:https://www.cnblogs.com/Brambling/archive/2018/08/06/9429662.html
-Advertisement-
Play Games

最近在MySQL中遇到分組排序查詢時,突然發現MySQL中沒有row_number() over(partition by colname)這樣的分組排序。並且由於MySQL中沒有類似於SQL Server中的row_number()、rank()、dense_rank()等排名函數,所有找到以下實 ...


最近在MySQL中遇到分組排序查詢時,突然發現MySQL中沒有row_number() over(partition by colname)這樣的分組排序。
並且由於MySQL中沒有類似於SQL Server中的row_number()、rank()、dense_rank()等排名函數,所有找到以下實現方法,在此簡單記錄一下。

 

首先創建一個表並插入測試數據。

create table demo.Student (
   ID int(11) NOT NULL AUTO_INCREMENT,
   StuNo varchar(32) NOT NULL,
   StuName varchar(10) NOT NULL,
   StuAge int(11) DEFAULT NULL,
   PRIMARY KEY (ID)
 )
 engine=innodb auto_increment=1 default charset=utf8 collate=utf8_general_ci;

insert into demo.Student(StuNo,StuName,StuAge) values('A001','小明',22);
insert into demo.Student(StuNo,StuName,StuAge) values('A005','小李',23);
insert into demo.Student(StuNo,StuName,StuAge) values('A007','小紅',24);
insert into demo.Student(StuNo,StuName,StuAge) values('A003','小明',22);
insert into demo.Student(StuNo,StuName,StuAge) values('A002','小李',23);
insert into demo.Student(StuNo,StuName,StuAge) values('A004','小紅',24);
insert into demo.Student(StuNo,StuName,StuAge) values('A006','小王',25);

select * from demo.Student;

測試數據如下:

 

實現row_number()排名函數,按學號(StuNo)排序。

-- @row_number:=0,設置變數@row_number的初始值為0。
-- @row_number:=@row_number+1,累加@row_number的值。
select ID,StuNo,StuName,StuAge,@row_number:=@row_number+1 as row_number 
from demo.Student a,
(
    select @row_number:=0
) b
order by StuNo asc;

結果如下:

 

實現rank()排名函數,按學生年齡(StuAge)排序。

-- @StuAge:=null,設置變數@StuAge的初始值為null
-- @rank:=0,設置變數@rank的初始值為0
-- @inRank:=1,設置變數@inRank的初始值為1
-- if(@StuAge=StuAge,@rank,@rank:=@inRank),指定排序列的值不變時,@rank的值不變;指定排序列的值變化時,@rank的值跳變為@inRank內部計數的值
-- @inRank:=@inRank+1,每一行自增1,用於實現內部計數
select t.ID,t.StuNo,t.StuName,t.StuAge,t.row_rank 
from 
(
    select ID,StuNo,StuName,StuAge,if(@StuAge=StuAge,@rank,@rank:=@inRank) as row_rank,@inRank:=@inRank+1,@StuAge:=StuAge 
    from demo.Student a,
    (
        select @StuAge:=null,@rank:=0,@inRank:=1 
    ) b 
    order by StuAge asc 
) t;

結果如下:

 

實現dense_rank()排名函數,按學生年齡(StuAge)排序。

-- @StuAge:=null,設置變數@StuAge的初始值為null
-- @rank:=0,設置變數@rank的初始值為0
-- if(@StuAge=StuAge,@rank,@rank:=@rank+1),指定排序列的值不變時,@rank的值不變;指定排序列的值變化時,@rank的值自增1
select t.ID,t.StuNo,t.StuName,t.StuAge,t.row_rank 
from 
(
    select ID,StuNo,StuName,StuAge,if(@StuAge=StuAge,@rank,@rank:=@rank+1) as row_rank,@StuAge:=StuAge
    from demo.Student a,
    (
        select @StuAge:=null,@rank:=0 
    ) b 
    order by StuAge asc 
) t;

結果如下:

 

實現row_number() over(partition by colname order by colname)分組排名函數,按學生年齡(StuAge)分組排序。

-- @StuAge:=null,設置變數@StuAge的初始值為null
-- @row_number:=0,設置變數@row_number的初始值為0
-- if(@StuAge=StuAge,@row_number:=@row_number+1,@row_number:=1),指定排序列的值不變時,@row_number的值自增1;指定排序列的值變化時,@row_number的值等於1
select t.ID,t.StuNo,t.StuName,t.StuAge,t.row_number 
from 
(
    select ID,StuNo,StuName,StuAge,if(@StuAge=StuAge,@row_number:=@row_number+1,@row_number:=1) as row_number,@StuAge:=StuAge 
    from demo.Student a,
    (
        select @StuAge:=null,@row_number:=0 
    ) b 
    order by StuAge asc 
) t;

結果如下:

 

實現分組聚合字元串,即把指定列的值拼成字元串。
在SQL Server中時利用了中間變數實現,現在在MySQL中就比較簡單了。
MySQL提供了一個group_concat()函數,可以把指定列的值拼成一個字元串,並可以按指定排序方式拼成字元,之間用逗號隔開。如下示例:

select group_concat(StuNo order by StuNo asc) as column1,group_concat(StuNo order by ID asc) as column2 
from demo.Student 

結果如下:

 

select StuName,group_concat(StuNo order by StuNo asc) as column1,concat('"',group_concat(StuNo order by StuNo asc),'"') as column2 
from demo.Student 
group by StuName 
order by StuAge 

結果如下:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.Linux基礎和分散式集群技術 學完此階段可掌握的核心能力: 熟練使用linux,熟練安裝Linux上的軟體,瞭解熟悉負載均衡、高可靠等集群相關概念,搭建互聯網高併發、高可靠的服務架構; 學完此階段可解決的現實問題: 搭建負載均衡、高可靠的伺服器集群,可以增大網站的併發訪問量,保證服務不間斷地對 ...
  • 其中:syspwd:sys的登陸密碼;MyOrcl:所創建的資料庫服務名。 其中:dump_name :所創建的數據泵名字;'E:\DumpFiles' :創建數據泵存放.dump文件的絕對路徑。 導出數據: 其中:schemas:需要導出的用戶名;dumpfile:預設在數據泵目錄下生成對應的.d ...
  • 1. innodb 行鎖是基於索引實現的,如果不通過索引訪問數據,innodb會使用表鎖。 http://www.cnblogs.com/MrHSR/p/9376086.html 2. Innodb 間隙鎖(Next-key)機制,以及innodb使用間隙鎖的原因 http://www.cnblog ...
  • 1.mongodb安裝包下載(mongodb-win32-x86_64-v3.4-latest.zip),解壓到D:\mongodb文件夾下(解壓前創建目錄即可),創建data、logs文件夾【創建mongodb.log文件】 鏈接:https://pan.baidu.com/s/1K7g36CA_ ...
  • 轉自: http://www.maomao365.com/?p=6208 摘要: GROUPING 用於區分列是否由 ROLLUP、CUBE 或 GROUPING SETS 聚合而產生的行 如果是原生態的行聚合,則返回0 ,新增的行數據就返回1 grouping 語法簡介 : GROUPING (< ...
  • 1.1 日誌文件與數據文件一致性 在上一章備份與恢復里瞭解到事務日誌的重要性,這篇重點來瞭解事務日誌。 事務日誌記錄了資料庫所有的改變,能恢復該資料庫到改變之前的任意狀態。在sql server實例每次啟動時都會去檢查數據文件與日誌文件的一致性。 包括日誌記錄的任何已提交的數據必須體現在數據文件上, ...
  • 問題來源:最近有同事需要執行批量刪除語句。根據他提供的業務需求,推薦他使用“TRUNCATE TABLE”語句。但使用該語句需要 ALTER許可權,這與執行用戶的角色不符。 解決辦法:使用EXECUTE AS語句修改執行許可權。代碼如下: 通過列印出來的loginame可以看出,執行用戶信息已經被修改。 ...
  • /*其實我也搞不懂為什麼要用SQL來創建,明明SQL Server有圖形化創建資料庫多省事啊!*/USE master;​DECLARE @sqlstr nvarchar(max)/*定義一個變數*/DECLARE @database_name nvarchar(20) = 'MyDB';/*這裡輸 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...