比较同一个表中的SQL Server中的行(或具有相同结构的不同表)

时间:2018-01-17 21:42:27

标签: sql sql-server tsql compare

我知道这是一个非常普遍的问题,但我想知道SQL或其他外部工具中的选项,以比较同一SQL表中或具有相同结构的2个表中的某些行。

这些表包含大量列(60)

例如,假设我们有两个具有相同ID和相似数据的不同行。

比较2时,结果中我们可能只是这些行之间的不同项吗?

例如:

Table : Col1 Col2 Col3 Col4 Col5 ....(until column 60)  
Row 1 : AAA  BBB  CCC  DDD  EEE  
Row 2 : AAA  BBB  CCC  DDD  DDD  

结果应该返回Col5有差异,但其他的是相同的。

正如我所提到的,这是一个非常开放的主题,但我想知道你的建议。

2 个答案:

答案 0 :(得分:0)

您可以使用外部工具。一个这样的工具是RedGate Data Compare。这是付费的,但你可以尝试14天。

Link to Redgate Data Compare

答案 1 :(得分:0)

您可能需要查看" EXCEPT"运营商。除了显示两个表之间的差异。结果将是第一张表中的记录。

SELECT tbl.* FROM (VALUES
  ( 1, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
, ( 2, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
, ( 3, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
, ( 4, 'AAA', 'BBB', 'CCC', 'DDD', 'DDD')
) tbl ([ID], [Column2], [Column3], [Column4], [Column5], [Column6]) 
EXCEPT
SELECT tbl.* FROM (VALUES
  ( 1, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
, ( 2, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
, ( 3, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
, ( 4, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
) tbl ([ID], [Column2], [Column3], [Column4], [Column5], [Column6]) 

db<>fiddle

results

或者您可以在同一张桌子上进行左连接。

;WITH
source_data
AS
(
    SELECT tbl.* FROM (VALUES
      ( 1, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
    , ( 2, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
    , ( 3, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
    , ( 4, 'AAA', 'BBB', 'CCC', 'DDD', 'DDD')
    , ( 1, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
    , ( 2, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
    , ( 3, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
    , ( 4, 'AAA', 'BBB', 'CCC', 'DDD', 'EEE')
    ) tbl ([ID], [Column2], [Column3], [Column4], [Column5], [Column6]) 
)
SELECT 
    tbl1.* 
FROM
    source_data AS tbl1
    LEFT JOIN source_data AS tbl2 ON tbl1.[ID] = tbl2.[ID]
WHERE 
    1=1
    AND 
    (
    tbl1.[Column2] != tbl2.[Column2]
    OR tbl1.[Column3] != tbl2.[Column3]
    OR tbl1.[Column4] != tbl2.[Column4]
    OR tbl1.[Column5] != tbl2.[Column5]
    OR tbl1.[Column6] != tbl2.[Column6]
    )

db<>fiddle

results