sql >> Database >  >> RDS >> Sqlserver

Hoe gegevens tussen twee tabellen in verschillende databases te vergelijken met SQL Server 2008?

select * 
from (
      select 'T1' T, *
      from DB1.dbo.Table
      except
      select 'T2' T, *
      from DB2.dbo.Table
     ) as T
union all
select * 
from (
      select 'T2' T, *
      from DB2.dbo.Table
      except
      select 'T1' T, *
      from DB1.dbo.Table
     ) as T
ORDER BY 2,3,4, ..., 1  -- make T1 and T2 to be close in output 2,3,4 are UNIQUE KEY SEGMENTS

Testcode:

declare @T1 table (ID int)
declare @T2 table (ID int)

insert into @T1 values(1),(2)
insert into @T2 values(2),(3)

select * 
from (
      select *
      from @T1
      except
      select *
      from @T2
     ) as T
union all
select * 
from (
      select *
      from @T2
      except
      select *
      from @T1
     ) as T

Resultaat:

ID
-----------
1
3

Opmerking:het kan lang duren om een ​​grote tabel te vergelijken bij het ontwikkelen van een "afgestemde" oplossing of refactorig, wat hetzelfde resultaat zal geven als REFERERCE - het kan verstandig zijn om eerst eenvoudige parameters te controleren:zoals

select count(t.*) from (
   select count(*) c0, SUM(BINARY_CHECKSUM(*)%1000000) c1 FROM T_REF_TABLE 
   -- select 12345 c0, -214365454 c1 -- constant values FROM T_REF_TABLE 
   except 
   select count(*) , SUM(BINARY_CHECKSUM(*)%1000000) FROM T_WORK_COPY 
) t

Als dit leeg is, heb je waarschijnlijk alles onder controle, en misschien kun je het wijzigen als je faalt, je zult "constante waarden FROM T_REF" zien om nog meer tijd te besparen voor de volgende controle!!!



  1. Controleer uw SQLite-versie

  2. Verander tabel/kolom/index namen grootte in orakel 11g of 12c

  3. Hoe te updaten vanuit SELECT in SQL Server

  4. Stappen die u moet nemen als u een MySQL-storing heeft