狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

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

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

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

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


假設我們有兩張表,分別為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