AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Inhalt einer Firebird-Tabelle übernehmen
Thema durchsuchen
Ansicht
Themen-Optionen

Inhalt einer Firebird-Tabelle übernehmen

Ein Thema von Luckner · begonnen am 3. Aug 2017 · letzter Beitrag vom 3. Aug 2017
Antwort Antwort
Luckner

Registriert seit: 28. Nov 2006
Ort: Berlin
418 Beiträge
 
Delphi 7 Enterprise
 
#1

Inhalt einer Firebird-Tabelle übernehmen

  Alt 3. Aug 2017, 16:29
Datenbank: Firebird • Version: 1.5 • Zugriff über: Dataset
Hallo an Alle,
ich würde gerne aus einer temporären Firebird-Tabelle alle Daten in eine andere Tabelle der selben Datenbank kopieren. Mit
Delphi-Quellcode:
    DatamoduleAuftrag.IBDataSetPositionen.Open;
    DataModuleArtikelAngebot.IBDataSetArtikelTemp.Open;
    DataModuleArtikelAngebot.IBDataSetArtikelTemp.First;

    with DataModuleArtikelAngebot.IBDataSetArtikelTemp do
    for i := 0 to DataModuleArtikelAngebot.IBDataSetArtikelTemp.RecordCount - 1 do
    begin
      DatamoduleAuftrag.IBDataSetPositionen.Append;
      DatamoduleAuftrag.IBDataSetProvisionenAUFTRID.AsInteger := AuftragsId;
      DatamoduleAuftrag.IBDataSetPositionenPOSTIONSNUMMER.AsInteger := DataModuleArtikelAngebot.IBDataSetArtikelTempPOSTIONSNUMMER.AsInteger;
      DatamoduleAuftrag.IBDataSetPositionenKENNZIFFER.AsInteger := DataModuleArtikelAngebot.IBDataSetArtikelTempKENNZIFFER.AsInteger;
      DatamoduleAuftrag.IBDataSetPositionenARTIKELNUMMER.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempARTIKELNUMMER.AsString;
      DatamoduleAuftrag.IBDataSetPositionenIHREARTIKELNUMMER.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempIHREARTIKELNUMMER.AsString;
      DatamoduleAuftrag.IBDataSetPositionenBEZEICHNUNG.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempBEZEICHNUNG.AsString;
      DatamoduleAuftrag.IBDataSetPositionenHINWEIS.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempHINWEIS.AsString;
      DatamoduleAuftrag.IBDataSetPositionenKUNDENBEZEICHNUNG.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempKUNDENBEZEICHNUNG.AsString;
      DatamoduleAuftrag.IBDataSetPositionenAUFDRUCK.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempAUFDRUCK.AsString;
      DatamoduleAuftrag.IBDataSetPositionenFORMAT.AsInteger:= StrToInt(DataModuleArtikelAngebot.IBDataSetArtikelTempFORMAT.AsString);
      DatamoduleAuftrag.IBDataSetPositionenFORMATB.AsInteger:= StrToInt(DataModuleArtikelAngebot.IBDataSetArtikelTempFORMATB.AsString);
      DatamoduleAuftrag.IBDataSetPositionenEINHEIT.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempEINHEIT.AsString;
      DatamoduleAuftrag.IBDataSetPositionenBUTTONS.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempBUTTONS.AsString;
      DatamoduleAuftrag.IBDataSetPositionenBLATTWAREANMERKUNG.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempBLATTWAREANMERKUNG.AsString;
      DatamoduleAuftrag.IBDataSetPositionenBLATTWARECOMBO.AsInteger := DataModuleArtikelAngebot.IBDataSetArtikelTempBLATTWARECOMBO.AsInteger;
      DatamoduleAuftrag.IBDataSetPositionenAUFROLLELEGEANWEISUNG2.AsString := DataModuleArtikelAngebot.IBDataSetArtikelTempAUFROLLELEGEANWEISUNG2.AsString;
    end;

    DatamoduleAuftrag.IBDataSetPositionen.Post;

    if DatamoduleAuftrag.IBTransaction1.InTransaction then DatamoduleAuftrag.IBTransaction1.Commit;
    DatamoduleAuftrag.IBDataSetPositionen.Close;

Bekomme jedoch den Fehler: "Nicht im Bearbeitungsmodus" Prozess wurde angehalten.

Finde den Fehler nicht.
Bitte um Hilfe.
Danke, Luckner
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Inhalt einer Firebird-Tabelle übernehmen

  Alt 3. Aug 2017, 16:47
Warum das With?

es fehlt DataModuleArtikelAngebot.IBDataSetArtikelTemp.Next in der Schleife.

Beim wievielten DS kommt der Fehler?
Statt
for i := 0 to DataModuleArtikelAngebot.IBDataSetArtikelTemp.RecordCount - 1 do besser
while not DataModuleArtikelAngebot.IBDataSetArtikelTemp.Eof do Ich würde die Kopie durch ein SQL-Statement erledigen.
Markus Kinzler
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#3

AW: Inhalt einer Firebird-Tabelle übernehmen

  Alt 3. Aug 2017, 16:54
Grobes Vorgehen bei einer Schleife über eine Tabelle ...
Delphi-Quellcode:
while not DataModuleArtikelAngebot.IBDataSetArtikelTemp.EoF do begin
  DatamoduleAuftrag.IBDataSetPositionen.Append;

  ... Wertezuweisungen

  DatamoduleAuftrag.IBDataSetPositionen.Post;
  DataModuleArtikelAngebot.IBDataSetArtikelTemp.Next;
end;
In Deinem Quelltext befindet sich das Post ausserhalb der Schleife, es gehört aber zu jedem Append ein Post. Das ist in Deinem Quelltext nicht gegeben.

Am Ende fragst Du nach, ob eine Transaktion offen ist, wenn ja, wird ein Commit gemacht. Im Quelltext wird aber keine Transaktion gestartet, so dass auch das Commit nie ausgeführt wird.

Wenn die Tabellen strukturell identisch sind, dürfte ein insert into NeueTabelle select * from AlteTabelle ausreichen und deutlich schneller sein.

Stimmen die Strukturen nicht überein, müssen halt die Spalten aufgeführt werden, ist nur etwas Schreibarbeit, aber sicherlich deutlich weniger Aufwand, als das zu programmieren.
  Mit Zitat antworten Zitat
Fritzew

Registriert seit: 18. Nov 2015
Ort: Kehl
678 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Inhalt einer Firebird-Tabelle übernehmen

  Alt 3. Aug 2017, 17:02
Zu dem Hier schon gesagten noch:

Append auf Positionen und zuweisen an Provisionen?
Delphi-Quellcode:
DatamoduleAuftrag.IBDataSetPositionen.Append;
// Das ist doch die falsche Tabelle oder?
DatamoduleAuftrag.IBDataSetProvisionenAUFTRID.AsInteger := AuftragsId;
Fritz Westermann
  Mit Zitat antworten Zitat
Luckner

Registriert seit: 28. Nov 2006
Ort: Berlin
418 Beiträge
 
Delphi 7 Enterprise
 
#5

AW: Inhalt einer Firebird-Tabelle übernehmen

  Alt 3. Aug 2017, 17:13
Danke an Euch und Fritzew, klasse gesehen. Wäre ich so schnell nicht drauf gekommen. Jetzt läuft es.

Gruß, Luckner
  Mit Zitat antworten Zitat
Antwort Antwort


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 23:40 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz