T1 (PK, A, B) ve T2 (PK, A, B) karşılaştırmak için.
Her iki tarafta da eksik anahtar değerlerini aramak için önce birincil anahtar kümelerini karşılaştırın:
SELECT T1.*, T2.* FROM T1 FULL OUTER JOIN T2 ON T1.PK=T2.PK WHERE T1.PK IS NULL OR T2.PK IS NULL;
Ardından tüm değer uyumsuzluklarını listeleyin:
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 ve B aynı türde olmalıdır. SELECT'i oluşturmak için BİLGİ ŞEMASI'nı kullanabilirsiniz. IS NULL sonuçlarını da dahil etmek için COALESCE'yi unutmayın. FULL OUTER JOIN ve COALESCE (T1.PK, 0) = COALESCE (T2.PK, 0) da kullanabilirsiniz.
Örneğin varchar türündeki sütunlar için:
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');