我知道这是一个非常普遍的问题,但我想知道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有差异,但其他的是相同的。
正如我所提到的,这是一个非常开放的主题,但我想知道你的建议。
答案 0 :(得分:0)
您可以使用外部工具。一个这样的工具是RedGate Data Compare。这是付费的,但你可以尝试14天。
答案 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])
或者您可以在同一张桌子上进行左连接。
;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]
)