Client #1: Vergibt in seinen Tabellen nur ID's 0...10000
Client #2: Vergibt in seinen Tabellen nur ID's 10001...20000
etc.
Dann kannst Du später einfach die Daten zusammenführen (lassen). Das macht der
SQL-Server automatisch, man muss ihm das nur sagen (Stichwort: Replikation). Natürlich geht das auch per Hand, indem Du einfach z.B. auf dem Ziel-Server (der im Netz) ab und an die Daten von den Clients saugst und die Client-Daten dann löschst.
Du sprichst außerdem von irgendwelchen Änderungen in der Struktur. Das ist -soweit ich weiss- nicht die Aufgabe einer Replikation, sondern vom Administrator, der dafür Sorge tragen muss, das die einzelnen
DB immer die gleiche Struktur aufweisen. Ich verwende dafür ein Tool von 'Red Gate', '
SQL-Compare' heißt das Teil. Das macht genau, was ich will: Es synchronisiert die Struktur, also Tabellenaufbau, Views, Stored Procedures etc. von zwei MS-
SQL Datenbanken.
Weiterhin merkt man, das Du hinsichtlich der Ausfallsicherheit etc. von Datenbanken verunsichert bist. Vermutlich hast Du vorher mit einer Desktop 'Datenbank' gearbeitet, z.B.
Access,
Paradox oder DBase. Da passiert sowas nämlich, das die
DB zerschossen ist, wenn beim Speichern der Strom ausfällt. Gegen ein richtiges
DBMS kannst Du während des speicherns treten (ok, nicht bei
MySQL), da passiert *gar nichts*. So eine richtige
DB sorgt auch dafür, das zwei Leute nicht gleichzeitig an Daten rumwuseln können, wenn Du ihr das sagst.
Allerdings benötigt man dafür ein wenig Grundwissen über
DB-Konzepte.