Einzelnen Beitrag anzeigen

Benutzerbild von Nersgatt
Nersgatt

Registriert seit: 12. Sep 2008
Ort: Emlichheim
693 Beiträge
 
Delphi 10.1 Berlin Professional
 
#16

Re: [SQL] Datensatz kopieren

  Alt 4. Dez 2008, 07:14
Hallo Thomas,

vielen Dank für die ausführliche Antwort.

Zitat von Jürgen Thomas:
Wenn Du aber auch eine Lösung innerhalb des DataSet (des NET-DataSet, nicht von Delphi-TDataset) in Betracht ziehst, kannst Du so vorgehen:
  • Hole die gewünschten Daten per FbDataAdapter.Fill in das DataSet.
  • Setze DataSet.EnforceConstraints auf false.
  • Kopiere die gewünschte Zeile mit DataTable.ImportRow.
  • Setze den ID-Wert, je nach Bedarf mit AutoIncrement innerhalb der DataTable oder durch Abruf des Generators (d.h. aus der internen Tabelle RDB$GENERATORS bzw. mit einem FbCommand über NEXT VALUE)
  • Speichere die Daten mit DbDataAdapter.Update
Wenn der Vorschlag etwas früher gekommen wäre, hätte ich die Lösung in Betracht gezogen. Aber die jetzige Lösung finde ich noch etwas besser, weil sie näher an der Datenbank ist. Das eigentliche Statement wird auf dem Server ausgeführt.

Zitat:
So, nachdem der Forum-Server wieder bereit ist, hier mein Kommentar:

Grundsätzlich ein mögliches Verfahren, zumal Du es für Deine Bedürfnisse etwas erweitert und verallgemeinert hast. Nur ein paar Anmerkungen:
  • In der konkreten Situation ist eine Transaction wahrscheinlich vernünftig. Wichtig ist aber, dass unter ADO.NET eine DbConnection nur so kurz wie möglich geöffnet sein soll und baldmöglichst wieder geschlossen wird.
  • Warum? Ist es nicht unnötige Last, immer wieder die Verbindung zu öffnen und zu schließen?

    Zitat:
  • Bei strFields2 kannst Du auf CAST und AS ID verzichten. Wichtig ist, dass die Datentypen übereinstimmen; aber das tun sie ja bei Deiner Konstruktion.
Dass ich auf das CAST verzichten kann, war mir nicht wirklich bewusst, weil ich solche Dinge immer im IBExpert vorbereite. Dort muss man CAST verwenden, weil man ja für die Parameter keinen Datentypen angeben kann.

Zitat:
  • Aber auch bei Dir geht es einfacher und trotzdem typsicher:
          c.Parameters.Add('@IDZIEL', fbdbtype.Integer).Value := iID;
  • Wird bei mir vom Compiler mit
    Zitat:
    [Pascal Fehler] UnitPaulCommon.pas(75): E2010 Inkompatible Typen: 'Object' und 'Integer'
    quittiert.

    Gruß,
    Jens
    Jens
      Mit Zitat antworten Zitat