MySQL 資料庫查詢數據,過濾重覆數據保留一條數據---(MySQL中的row_number變相實現方法)

来源:https://www.cnblogs.com/lairui1232000/archive/2019/11/16/11826772.html
-Advertisement-
Play Games

轉自: http://www.maomao365.com/?p=10564 摘要: 下文講述MySQL資料庫查詢重覆數據時,只保留一條數據的方法 實現思路: 在MySQL資料庫中沒有row_number函數,所以我們需變向實現此功能。 定義臨時變數 @keyId,@infoB 每次查詢時 都重新對 ...


轉自: http://www.maomao365.com/?p=10564  摘要:

下文講述MySQL資料庫查詢重覆數據時,只保留一條數據的方法 
實現思路:
在MySQL資料庫中沒有row_number函數,所以我們需變向實現此功能。
 

--1.基礎數據表查看
mysql> select * from `maomao365.com`;
+-------+------------+
| keyId | infoB |
+-------+------------+
| 1 | mysql test |
| 129 | sql |
| 12913 | sql |
| 12913 | sql |
| 12913 | sql |
+-------+------------+
5 rows in set (0.00 sec)

---2 群組編號
mysql> select if(@keyId=a.keyId and @infoB=a.infoB,@r:=@r+1,@r:=1) as rowNumber,a.*,@keyId:=a.keyId,@infoB:=a.infoB
-> from (select @keyId:=null,@infoB:=null,@r:=0) r, (select keyId,infoB from `maomao365.com` order by keyId) a;
+-----------+-------+------------+-----------------+-----------------+
| rowNumber | keyId | infoB | @keyId:=a.keyId | @infoB:=a.infoB |
+-----------+-------+------------+-----------------+-----------------+
| 1 | 1 | mysql test | 1 | mysql test |
| 1 | 129 | sql | 129 | sql |
| 1 | 12913 | sql | 12913 | sql |
| 2 | 12913 | sql | 12913 | sql |
| 3 | 12913 | sql | 12913 | sql |
+-----------+-------+------------+-----------------+-----------------+
5 rows in set (0.00 sec)

---3 重覆數據只顯示一條
mysql> select * from (select if(@keyId=a.keyId and @infoB=a.infoB,@r:=@r+1,@r:=1) as rowNumber,a.*,@keyId:=a.keyId,@infoB:=a.infoB
-> from (select @keyId:=null,@infoB:=null,@r:=0) r, (select keyId,infoB from `maomao365.com` order by keyId) a
-> ) as t where t.rowNumber =1;
+-----------+-------+------------+-----------------+-----------------+
| rowNumber | keyId | infoB | @keyId:=a.keyId | @infoB:=a.infoB |
+-----------+-------+------------+-----------------+-----------------+
| 1 | 1 | mysql test | 1 | mysql test |
| 1 | 129 | sql | 129 | sql |
| 1 | 12913 | sql | 12913 | sql |
+-----------+-------+------------+-----------------+-----------------+
3 rows in set (0.00 sec)

 

定義臨時變數 @keyId,@infoB
每次查詢時 都重新對 @keyId,@infoB 賦值
在賦值前,都採用If對其進行判斷,如果當前行記錄信息和臨時變數中的值相同時,則作為相同數據@r變數加1,否則@r變數變為1
採用以上模式,可以將重覆的行記錄進行編號

最後對重新編號後的記錄,檢索出row_number等於1的信息
  Mysql row_number函數實現方法


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

-Advertisement-
Play Games
更多相關文章
  • 03.遠程登錄和複製文件 序號|命令|對應英文|作用 | | | 01|ssh 用戶名@ip|secure shell|關機/重啟 02|scp 用戶名@ip:用戶名或路徑 用戶名@ip:文件名或路徑|secure copy|遠程複製文件 3.1 ssh 基礎(重點) 在Linux中SSH是非常常用 ...
  • 磁碟配額的概念 quota 磁碟配額功能只在指定的文件系統(分區)內有效,未設置配額的文件系統不受限制。 quota 針對指定的用戶賬號、組賬號進行限制,其他用戶或組不受影響。 磁碟配額可以進行兩方面的限制: 磁碟容量 文件數量 磁碟容量:限制用戶能夠使用的磁碟數據塊(block)大小,也就是限制磁 ...
  • 轉自: http://www.maomao365.com/?p=8919 摘要: 下文講述使用sql腳本對數據表或數據列添加註釋(備註說明)的方法分享,如下所示: 實驗環境:sql server 2008 r2 實現思路: 使用系統存儲過程sys.sp_addextendedproperty對錶和列 ...
  • 資料庫分類 關係型資料庫(SQL):存儲方式固定,安全 非關係型資料庫(NoSQL):存儲方式比較靈活,存儲數據的效率比較高,不太安全 MySQL是一種關係型資料庫管理系統(採用關係模型來組織管理數據的資料庫系統) 註意事項 大小寫:不嚴格區分,預設大寫為程式代碼,小寫為程式員寫的代碼 語句結束符: ...
  • Date:2019-11-12 讀前思考: redis每次必問的問題,在大腦裡面先回想一下,能否答出一二? 題1:Redis雪崩瞭解麽? 題2:瞭解Redis緩存穿透和擊穿麽? 題3:你知道Redis緩存雪崩、穿透和擊穿 的三者區別嗎,可以結合具體的應用場景業務來說說?如何避免緩存雪崩、穿透和擊穿呢 ...
  • ...
  • 鏈接:https://bdcc.bigdataedu.org/block/50(需賬號登錄) ...
  • 鏈接:https://bdcc.bigdataedu.org/block/48(需賬號登錄) ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...