AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Datensatz von Datenbank zu Datenbank kopieren / updaten
Thema durchsuchen
Ansicht
Themen-Optionen

Datensatz von Datenbank zu Datenbank kopieren / updaten

Ein Thema von stekohl · begonnen am 12. Jun 2008 · letzter Beitrag vom 9. Jul 2008
 
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#5

Re: Datensatz von Datenbank zu Datenbank kopieren / updaten

  Alt 8. Jul 2008, 18:07
Angenommen du hast zwei baugleiche Tabellen in versch. Datenbanken (mit Primärschlüssel!!!).
Ohne Primärschlüssel ist ein Abgleich nicht möglich!

Du öffnest beide Tabellen mit SELECT * FROM Tabelle ORDER BY Pkfelder.
Du durchläufst beide Tabellen und vergleichst jeweils den Primärschlüssel.
Sind beide Schlüssel gleich, musst du herausfinden, ob du A->B oder B->A aktualisieren willst.
Vielleicht willst du immer nur A->B, das ist einfacher.
Delphi-Quellcode:
procedure CopyDataSetRecord(Src,Dst: TDataSet; TagMask:Integer=0);
var
   i: Integer;
   fSrc,fDst: TField;
begin
   for i := 0 to Src.FieldCount-1 do
   begin
      fSrc := Src.Fields[i];
      fDst := Dst.FindField(fSrc.FieldName);

      if Assigned(fDst) and ((fSrc.Tag and TagMask)=0) then
      begin
         fDst.Value := fSrc.Value;
      end;
   end;
end;
Wichtig beim Kopieren ist, dass die Primärschlüsselfeld(er) nicht mitkopiert werden.
Das lässt sich durch geschicktes Einsetzen der TagMask erreichen.

Sind die Primärschlüssel unterschiedlich, musst du schauen, ob in der Tabelle von DB-A ein Datensatz vorhanden ist, der in DB-B fehlt (oder umgekehrt).
Jenachdem wird ein Delete oder Insert fällig und wieder dient obige Prozedure zum Kopieren der Daten.
Dann solange weitermachen, bis bei beiden Datensets Eof=True ist.
Andreas
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:50 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-2025 by Thomas Breitkreuz