MySQL--如何快速對比數據

来源:https://www.cnblogs.com/TeyGao/archive/2018/02/04/8414657.html
-Advertisement-
Play Games

在MySQL運維中,研發同事想對比下兩個不同實例上的數據並找出差異,除主鍵外還需要對比每一個欄位,如何做呢? 第一種方案,寫程式將兩個實例上的每一行數據取出來進行對比,理論可行,但是對比時間較長。 第二種方案,對每一行數據所有欄位合併起來,取checksum值,再按照checksum值對比,看著可行 ...


在MySQL運維中,研發同事想對比下兩個不同實例上的數據並找出差異,除主鍵外還需要對比每一個欄位,如何做呢?

第一種方案,寫程式將兩個實例上的每一行數據取出來進行對比,理論可行,但是對比時間較長。

第二種方案,對每一行數據所有欄位合併起來,取checksum值,再按照checksum值對比,看著可行,嘗試下。

首先要合併所有欄位的值,選用MySQL提供的CONCAT函數,如果CONCAT函數中包含NULL值,會導致最終結果為NULL,因此需要使用IFNULL函數來替換NULL值,如:

CONCAT(IFNULL(C1,''),IFNULL(C2,''))

加入表有很多行,手動拼個腳本比較累,別急,可以使用information_schema.COLUMNS來處理:

## 獲取列名的拼接串
SELECT
GROUP_CONCAT('IFNULL(',COLUMN_NAME,','''')')
FROM information_schema.COLUMNS 
WHERE TABLE_NAME='table_name';

假設我們有測試表:

CREATE TABLE t_test01
(
    id INT AUTO_INCREMENT PRIMARY KEY,
    C1 INT,
    C2 INT
)

我們便可以拼接出下麵的SQL:

SELECT
id,
MD5(CONCAT(
IFNULL(id,''),
IFNULL(c1,''),
IFNULL(c2,''),
)) AS md5_value
FROM t_test01

在兩個實例上執行下,然後把結果使用beyond compare對比下,就很容易找出不相同的行以及主鍵ID

對於數據量較大的表,執行出來的結果集也很大,對比起來比較費勁,那就先嘗試縮小結果集,可以將多行記錄的md5值合併起來求MD5值,如果最後MD5值相同,則這些行相同,如果不同,則證明存在差異,再按照這些行進行逐行對比。

假設我們按照1000行一組來進行對比,如果需要將分組後的結果合併,需要使用GROUP_CONCAT函數,註意在GROUP_CONCAT函數中添加排序保證合併數據的順序, SQL如下:

SELECT
min(id) as min_id,
max(id) as max_id,
count(1) as row_count,
MD5(GROUP_CONCAT(
MD5(CONCAT(
IFNULL(id,''),
IFNULL(c1,''),
IFNULL(c2,''),
)) ORDER BY id
))AS md5_value
FROM t_test01
GROUP BY (id div 1000)

執行結果為:

min_id    max_id    row_count    md5_value
0        999        1000         7d49def23611f610849ef559677fec0c
1000     1999       1000         95d61931aa5d3b48f1e38b3550daee08
2000     2999       1000         b02612548fae8a4455418365b3ae611a
3000     3999       1000         fe798602ab9dd1c69b36a0da568b6dbb 

當差異數據較少時,即使需要對比上千萬數據,我們可以輕鬆根據根據min_id和max_id來快速定位到哪1000條數據里存在差異,再進行逐行MD5值對比,最終找到差異行。

最終對比圖:

##=====================================================================##

PS:

在使用GROUP_CONCAT時,需要配置MySQL變數group_concat_max_len,預設值為1024,超出部分會被階段。

參考鏈接:https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html

##=====================================================================##

提前祝各位春節快樂

 


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

-Advertisement-
Play Games
更多相關文章
  • Quartz 是什麼? Quartz 是作業調度系統,可以集成進其他軟體系統。這裡【作業調度程式】一詞是指,在預定義時間執行(或通知)其他組件的系統。 Quartz 有什麼優點? 靈活,有多種使用方式,可混合使用 輕量,只需很少的配置 容錯性好 具有持久化功能,程式重啟時,可記住已計劃的任務 Qua ...
  • Entity Framework Codefirst的配置步驟: (1) 安裝命令: install-package entityframework (2) 創建實體類,註意virtual關鍵字在導航屬性中的用法 (3) 創建DbContext類,為每個entity set創建一個DbSet; 指定 ...
  • 1. 實現DataGrid column的顯示和隱藏功能; (1). 定義ContextMenu ,該ContextMenu僅可使用於DataGrid的DataGridColumnHeader; (2). 自定義顯示隱藏的制轉換器; 2. 在實現DataGridColumn Filter 功能時,可 ...
  • 本文目錄:1. Tomcat連接器協議類型2. Tomcat與httpd/nginx結合的方式3. Tomcat + nginx4. Tomcat + httpd(mod_jk) 4.1 編譯mod_jk模塊 4.2 配置httpd與tomcat的ajp連接 4.3 通過mod_jk負載均衡tomc ...
  • 簡介 IPC 主要有消息隊列、信號量和共用記憶體3種機制。和文件一樣,IPC 在使用前必須先創建,使用 ipcs 命令可以查看當前系統正在使用的 IPC 工具: 由以上可以看出,一個 IPC 至少包含 key值、ID值、擁有者、許可權和使用的大小等關鍵信息。如果需要手工刪除某個 IPC 機制,可以使用 ...
  • htpasswd用於為指定用戶生成基於網頁用戶身份認證的密碼,由httpd-tools軟體包提供。支持3種加密演算法:MD5、SHA和系統上的crypt()函數,不指定演算法時,預設為md5。 例如: (1).使用"-n"選項直接將結果輸出到標準輸出而不創建passwdfile。 (2).使用批處理模式 ...
  • 有些時候因為特殊需求,需要在已安裝的httpd上添加一些額外的模塊,這時候要使用httpd-devel中的apxs工具。要使用這個擴展機制,你的平臺必須支持DSO特性,即要求Apache httpd必須內建了mod_so模塊。 apxs添加模塊的方法很簡單,以下是幾個可能用上的選項。 -c mod_ ...
  • sed 是一種流編輯器,一次處理一行內容,處理時,把當前處理的行存儲在臨時緩衝區,稱為模式空間,接著用sed命令處理模式空間中的內容,處理完成後,把緩衝區的內容送往屏幕。然後讀入下行,執行下一個迴圈。 用法:sed [option]... 'script' inputfile... # :指定某行, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...