Du kannst innerhalb der MS
SQL Welt auch ein Feature nutzen, das 2
DB untereinander sichtbar macht. Bei MS nennt es sich Linked Server.
Hier ist eine Erklärung von MS:
https://docs.microsoft.com/en-us/sql...l-server-ver15
Beispielcode von dort
Code:
-- linked server definieren
-- zur Instanz: SRVR002\ACCTG
USE [master]
GO
EXEC master.dbo.sp_addlinkedserver
@server = N'SRVR002\ACCTG',
@srvproduct=N'
SQL Server' ;
GO
-- linked server configurieren
EXEC master.dbo.sp_addlinkedsrvlogin
@rmtsrvname = N'SRVR002\ACCTG',
@locallogin = NULL ,
@useself = N'True' ;
GO
Damit ist ein transparenter Zugriff auf die andere
DB per
SQL möglich und damit hast du per
SQL alle Möglichkeiten die
SQL bieten.
Beispielzugriff
Code:
-- Zugriff auf die andere
DB prüfen
SELECT name FROM [SRVR002\ACCTG].master.sys.databases ;
GO
Ein vergleich kann man bspw. durch einen simplen Join auf die Primärschlüssel machen (wenn die denn gleich sein sollten, also z.B. bei einem Abgleich mit einem Datenbankbackup)
Code:
-- gib alle customer ID aus, außer denen, die bereits in der Archivdatenbank von 2010 sind
Select id from customer c
except
Select id from [ARCH\CDB2010].dbo.customer carch
Hat man unterschiedliche Schlüsseldaten, weil es um unabhängige oder unspezifische Daten geht, kann man genau diese Schlüsseldaten weglassen und dennoch mit except ein ähnliches Ergebnis erzielen. Also z.B. Daten unterschiedlicher CRM Systeme vergleichen.
Code:
-- gib alle customer Daten aus, außer denen, die bereits im anderen CRM System stehen
Select companyname, street, city from customer c
except
Select firmenname, strasse, stadt from [SRV\OTHERCRM].dbo.crmkundendaten crm
Dieses Statement ist offensichtlich leicht geschrieben, aber der Teufel steckt natürlich im Detail. Schreibweise der Firmennamen, Straße mit oder ohne Hausnummer usw.
Aber auf die Art käme man ohne dicke (und teuere) extra Tools aus.