sql >> Databáze >  >> RDS >> Sqlserver

Porovnejte hodnotu více sloupců ze dvou různých databází

Za předpokladu, že uvažujete NULL být stejný (zatímco SQL Server nikoli):

SELECT 
  d1.col1, d1.col2, d1.col3, d1.col4,
  d2.col1, d2.col2, d2.col3, d2.col4,
  [RESULT] = CASE 
    WHEN (d1.col2 = d2.col2 OR (d1.col2 IS NULL AND d2.col2 IS NULL))
     AND (d1.col3 = d2.col3 OR (d1.col3 IS NULL AND d2.col3 IS NULL))
     AND (d1.col4 = d2.col4 OR (d1.col4 IS NULL AND d2.col4 IS NULL))
    THEN 1 ELSE 0 END
FROM ABC.dbo.tbl_123 AS d1
FULL OUTER JOIN
XYZ.dbo.tbl_123 AS d2
  ON d1.col1 = d2.col2;


  1. Průvodce návrhem databáze pro online nákupní košík v MySQL

  2. COALESCE Funkce v TSQL

  3. GROUP nebo DISTINCT po JOIN vrátí duplikáty

  4. MySQL Zobrazit uživatele