![]() |
Datenbank: MSSQL • Version: 2012 • Zugriff über: Delphi
MS SQL Server Tabellen überprüfen
Hallo Leute,
ich suche so etwas wie IBExpert für den MS SQL Server. Ich habe zwei Datenbanken welche genau gleich sind. D.h. es gibt etliche Tabellen in den beiden Datenbanken. Ich möchte nun wissen welche Datensätze in welchen Tabellen unterschiedlich sind ? Kennt jemand so etas ? Danke Dumpfbacke |
AW: MS SQL Server Tabellen überprüfen
Fällt mir spontan
![]() ![]() |
AW: MS SQL Server Tabellen überprüfen
Visual Studio (Community Edition) hat auch Schema- und Daten-Vergleichsfunktionen eingebaut.
|
AW: MS SQL Server Tabellen überprüfen
|
AW: MS SQL Server Tabellen überprüfen
|
AW: MS SQL Server Tabellen überprüfen
Ich hätte noch OpenDBDiff im Angebot:
![]() Edit: Sorry, OpenDBDiff kann nur Schemas und keine Daten vergleichen :\ |
AW: MS SQL Server Tabellen überprüfen
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: ![]() 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:
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)
-- Zugriff auf die andere DB prüfen
SELECT name FROM [SRVR002\ACCTG].master.sys.databases ; GO
Code:
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.
-- 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
Code:
Dieses Statement ist offensichtlich leicht geschrieben, aber der Teufel steckt natürlich im Detail. Schreibweise der Firmennamen, Straße mit oder ohne Hausnummer usw.
-- 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 Aber auf die Art käme man ohne dicke (und teuere) extra Tools aus. |
AW: MS SQL Server Tabellen überprüfen
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:09 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz