LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

SQL常用算法-兩張相同格式表查找一致/不一致數據

admin
2024年3月30日 12:55 本文熱度 806

實際項目中,存在這么一種場景,測試環境測試完成后,搬遷至正式環境重新取數,但是需要確定正式環境數據與測試環境完全一致,我們可以比較兩張表中是否存在不一致數據,如果查詢不出,即表示正式環境數據可用。


假設我們有兩張表,分別為table1和table2,且它們具有相同的字段結構(例如都有字段A, B, C)。為了找出這兩張表中完全一致的數據和完全不一致的數據,我們可以分別進行如下操作:


查找完全一致的數據:

-- 定義一個臨時表,存儲table1的所有數據以及對應的表名

CREATE TEMPORARY TABLE temp_table1 AS

SELECT *, 'table1' as source FROM table1;


-- 同理,定義一個臨時表,存儲table2的所有數據以及對應的表名

CREATE TEMPORARY TABLE temp_table2 AS

SELECT *, 'table2' as source FROM table2;


-- 找出在兩個表中完全一致的數據

SELECT *

FROM (

    SELECT * FROM temp_table1

    UNION ALL

    SELECT * FROM temp_table2

) AS combined_tables

GROUP BY A, B, C

HAVING COUNT(*) = 2;

上述SQL首先創建了兩個臨時表并標記來源,然后通過UNION ALL合并所有數據,最后通過GROUP BY和HAVING子句篩選出在兩個表中都出現過的(即完全一致的)記錄。


查找不一致的數據:

這里假設為在一張表中存在的記錄,在另一張表中不存在。

-- 查找只存在于table1但不在table2中的記錄

SELECT * FROM table1

WHERE NOT EXISTS (SELECT 1 FROM table2 WHERE table2.A = table1.A AND table2.B = table1.B AND table2.C = table1.C);


-- 查找只存在于table2但不在table1中的記錄

SELECT * FROM table2

WHERE NOT EXISTS (SELECT 1 FROM table1 WHERE table1.A = table2.A AND table1.B = table2.B AND table1.C = table2.C);

以上SQL分別查詢了在table1中但不在table2中的記錄,以及在table2中但不在table1中的記錄,這就是我們所說的“完全不一致”的數據。


該文章在 2024/3/30 12:55:50 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
中文字幕乱码中文乱码二区 | 中文字幕HD天堂字幕乱码五月 | 亚洲欧美综合少妇 | 一本精品久久精品 | 亚洲国产美国国产综合一区 | 午夜丰满少妇性开放视频 |