![]() |
AW: Datensatz in einer Datenbank kopieren
Warum nicht per SQL?
|
AW: Datensatz in einer Datenbank kopieren
Zitat:
Die Procedure
Delphi-Quellcode:
ist sauber und fehlerfrei.
DuplicateCurrentRecord()
Sie ist so konstruiert, dass dem Programmierer nach dem Duplizieren eines Datensatzes alle Wege offenstehen. |
AW: Datensatz in einer Datenbank kopieren
gefallen tut sie mir schon.
ich wollte nur nicht alle felder kopieren, sondern nur ein paar ausgewählte. deshalb hab ich mur manche sachen bei dir abgeschaut |
AW: Datensatz in einer Datenbank kopieren
Zitat:
Delphi-Quellcode:
Auf jeden Fall macht es Sinn deine Anforderung durch Benutzung von "Basisfunktionen" zu lösen, als nur eine Funktion zu haben, die Alles macht.
// alle Felder löschen die in der Liste übergeben wurden
procedure ClearDbFields(ds:TDataset; feldliste:array of string); var i : Integer; f : TField; begin for i:=Low(feldliste) to High(feldliste) do begin f := ds.FindField(feldliste[i]); if Assigned(f) then f.Clear; // Set Field to NULL end; end;
Delphi-Quellcode:
Du kannst auch das Property Tag verwenden, um zwischen erwünschten und unerwünschten Feldern zu unterscheiden:
DuplicateCurrentRecord(aDataset); // zuerst alles kopieren
ClearDbFields(aDataset, ['Feld1', 'Feld2']); // dann das Löschen was nicht erwünscht ist
Delphi-Quellcode:
Auf jeden Fall sind die hier gezeigten Funktionen wiederverwendbar und können so für jede Tabelle benützt werden.
procedure ClearTaggedDbFields(ds:TDataset; mask:integer);
var i : Integer; f : TField; begin for i:=0 to ds.fields.Count-1 do begin f := ds.fields[i]; if (f.Tag and mask) <> 0 then f.Clear; end; end; |
AW: Datensatz in einer Datenbank kopieren
Da SQL in der Datenbankangabe steht, könnte es auch sein, dass folgendes über eine abgesetzte Query geht:
Code:
Grüße in die Runde
Select * into employee_backup from employee
Martin |
AW: Datensatz in einer Datenbank kopieren
Es geht doch eher darum, einen einzelnen Datensatz zu kopieren
|
AW: Datensatz in einer Datenbank kopieren
In der Tat, der Vorschlag ist updatefähig, z. B. mit folgendem Schnipsel:
Code:
Grüße in die Runde // Martin
var V:Variant;
i:integer; begin with Query1 do begin if (not Active)or(isEmpty) then exit; // Variant Array aufbauen V := VarArrayCreate([0,FieldCount-1], varVariant); for i:=0 to FieldCount-1 do // Für alle Felder die Beschreibbar sind hole Werte ins Array if (not Fields[i].ReadOnly) and(Fields[i].FieldName <> KeyFieldName) then V[i]:=Fields[i].Value; // Leeren Datensatz in Memory anlegen Insert; // Wo Werte im Array sind, diese in die Felder eintragen for i:=0 to FieldCount-1 do if (not Fields[i].ReadOnly) then Fields[i].Value := V[i]; // schreiben, eventuell auch später post; end; end; |
AW: Datensatz in einer Datenbank kopieren
Hauptächlich ist ja das Problem, dass ich die Funktionen 2x aufrufen muss, bis sie richtig funktioniert.
Sonst bekomme ich die genannte Exception. Mir ist aufgefallen, dass die Exception meistens eintritt, wenn ich einen Datensatz in der Mitte der Tabelle auswähle. Mit dem letzten angezeigten Datensatz ist das kein Problem. Hat das vielleicht dann etwas mit den Einstellungen der CDS oder so zu tun? |
AW: Datensatz in einer Datenbank kopieren
Wenn Du in einem Event den Datensatzzeiger veränderst, dann passiert genau das: Obskurer und sporadischer Verlust des Einfügemodus.
Ich würde mir eine kleines Projekt bauen, das das Problem beschreibt, also z.B.: 1x Form, 1x Button (zum Start des Tests) 1x CDS, 1x Beispieldaten. Von mir aus noch ne Datasource und ein Grid, damit man die Daten sieht. Im Click-Event des Buttons dann der Code, der den aktuellen Record ans Ende dupliziert. Sonst nix! Probieren. Gehts? Aha, liegt der Fehler wohl woanders. Geht nicht? Dann stell dein Projekt hier rein und andere sehen, ob sie das reproduzieren können oder einen robusten Workaround parat haben. Wenn Du alle Probleme, bei denen Du nicht sofort weiterkommst, mit der Holzfällermethode umgehst, na denn 'Gute Nacht'. Mein Versuch wäre:
Delphi-Quellcode:
Wenn Das nicht geht, liegst am CDS (glaube ich nicht) oder an erwähnten Seiteneffekten (Events, OnCalcField etc.)
Procedure DuplicateRecord(aDS : TDataset);
Var Data : Array Of Variant; I : Integer; Begin SetLength (Data, aDS.FieldCount); For i:=0 to aDS.FieldCount - 1 do Data[i] := aDS.Fields[i].Value; aDS.Append; For i:=0 to aDS.FieldCount - 1 do If CanCopyField(aDS.Fields[i]) then aDS.Fields[i].Value := Data[i]; aDS.Post; End; Ja, der Code ist fast identisch mit dem von mschaefer. Hab ich eben erst gemerkt. |
AW: Datensatz in einer Datenbank kopieren
habe die lösung gefunden :)
hab in der DataSource beim OnStateChange ein SetFocus gemacht und deshalb ist er immer wieder rausgesprungen :oops: aber noch vielen dank für die hilfe!!:thumb: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:25 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