Comparar T1 (PK, A, B) y T2 (PK, A, B).
Primero, compare los conjuntos de claves primarias para buscar valores de clave faltantes en ambos lados:
SELECT T1.*, T2.* FROM T1 FULL OUTER JOIN T2 ON T1.PK=T2.PK WHERE T1.PK IS NULL OR T2.PK IS NULL;
Luego enumere todas las discrepancias de valores:
SELECT T1.PK, 'A' AS columnName, T1.A AS leftValue, T2.A AS rightValue FROM T1 JOIN T2 ON T1.PK=T2.PK WHERE COALESCE(T1.A,0) != COALESCE(T2.A,0)
UNION ALL
SELECT T1.PK, 'B' AS columnName, T1.B AS leftValue, T2.B AS rightValue FROM T1 JOIN T2 ON T1.PK=T2.PK WHERE COALESCE(T1.B,0) != COALESCE(T2.B,0)
A y B deben ser del mismo tipo. Puede utilizar ESQUEMA DE INFORMACIÓN para generar SELECCIONAR. No olvide el COALESCE para incluir también los resultados IS NULL. También puede usar FULL OUTER JOIN y COALESCE (T1.PK, 0) = COALESCE (T2.PK, 0).
Por ejemplo, para columnas de tipo varchar:
SELECT concat('SELECT T1.PK, ''', COLUMN_NAME, ''' AS columnName, T1.', COLUMN_NAME, ' AS leftValue, T2.', COLUMN_NAME, ' AS rightValue FROM T1 JOIN T2 ON T1.PK=T2.PK WHERE COALESCE(T1.',COLUMN_NAME, ',0)!=COALESCE(T2.', COLUMN_NAME, ',0)')
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME='T1' AND DATA_TYPE IN ('nvarchar','varchar');