AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Lazarus (IDE) Fehler beim Löschen und Einfügen der Datensätzen.
Thema durchsuchen
Ansicht
Themen-Optionen

Fehler beim Löschen und Einfügen der Datensätzen.

Ein Thema von Luckner · begonnen am 18. Apr 2023 · letzter Beitrag vom 18. Apr 2023
Antwort Antwort
Luckner

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

Fehler beim Löschen und Einfügen der Datensätzen.

  Alt 18. Apr 2023, 11:16
Hallo,
Habe folgende Routine:

Delphi-Quellcode:
if ButtonStanze.Color = $00FF00 then
  begin
    DataModuleAbhaengikeiten.ZConnectionAbhaengikeiten.Connect;
    DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Close;
    DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.SQL.Clear;
    DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.SQL.Add('SELECT * FROM ARTIKEL_STANZE WHERE ARTIKEL_NR = ' + QuotedStr(EditArtikelNr.Text));
    DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Open;

    if not DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.IsEmpty then
    begin
      ShowMessage('Bin im Teil 1');
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Close;
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.SQL.Clear;
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.SQL.Add('delete FROM ARTIKEL_STANZE WHERE ARTIKEL_NR = ' + QuotedStr(EditArtikelNr.Text));
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.ExecSQL;
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Close;
      DataModuleAbhaengikeiten.ZConnectionAbhaengikeiten.Disconnect;
    end;

    if EditStanzeNr.Text <> 'then
    begin
      ShowMessage('Bin im Teil 2');
      DataModuleAbhaengikeiten.ZConnectionAbhaengikeiten.Connect;
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Open;
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Append;
      ShowMessage('Bin im Teil 3');
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_GridSTANZEN_NR.AsInteger:= StrToInt(EditStanzeNr.Text);
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_GridARTIKEL_NR.AsInteger:= StrToInt(EditArtikelNr.Text);

      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Post;
      ShowMessage('Bin im Teil 4');
      DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Grid.Close;
      DataModuleAbhaengikeiten.ZConnectionAbhaengikeiten.Disconnect;
    end;
  end;
folgendes geschieht:
1) Wenn in dieser Tabelle kein Eintrag existiert, wird ein Datensatz eigefügt und Routine läuft über 'ShowMessage 2 bis 4 ohne Probleme.
2)Wenn in dieser Tabelle ein Eintrag existiert, wird dieser gelöscht (sehe ich direkt in der Tabelle) 'ShowMessage 1, 2 und Routine ergibt einen Fehler:
'Projekt Stanzen hat Exception-Klasse ausgelöst mit der Meldung: Can not open a Resultset'.
3) Da im Punkt 2) der Eintrag gelöscht wurde, ist ein nochmaliger Aufruf dieser Routine wieder ohne Fehler (wie beim Punkt 1).
Und so im Kreis. Woran liegt es, dass nach direktem Löschen eine Eintrages, kein Append funktioniert?

Habe schon in einem anderem entsprechendem Forum auch diese Fehlermeldung beschrieben, mit den Antworten, dass es unter SQL kein Append gibt und weil das Dataset mit einem DBGrid in Verbindung steht.
Habe diese Routine ebenfalls unter Delphi nachgebaut und dort funktioniert sie ohne Probleme.
Diese Fehlermeldung komt auch von einer ZEOS-Subroutine.

Gruß, Luckner
  Mit Zitat antworten Zitat
Frickler

Registriert seit: 6. Mär 2007
Ort: Osnabrück
563 Beiträge
 
Delphi XE6 Enterprise
 
#2

AW: Fehler beim Löschen und Einfügen der Datensätzen.

  Alt 18. Apr 2023, 11:29
Was ist, wenn Du das Löschen auch über das DataSet machst (wie das Anhängen) und nicht via SQL-Kommando?
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.733 Beiträge
 
Delphi 6 Enterprise
 
#3

AW: Fehler beim Löschen und Einfügen der Datensätzen.

  Alt 18. Apr 2023, 11:51
Nach dem Löschen hast du in deiner Komponente das SQL-Statement zum Löschen drin und nicht mehr das zum Anzeigen der Daten.

Das hier im Teil 2 einfügen sollte helfen:

DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Gr id.SQL.Clear;
DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_Gr id.SQL.Add('SELECT * FROM ARTIKEL_STANZE WHERE ARTIKEL_NR = ' + QuotedStr(EditArtikelNr.Text));
Ralph
  Mit Zitat antworten Zitat
Luckner

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

AW: Fehler beim Löschen und Einfügen der Datensätzen.

  Alt 18. Apr 2023, 12:47
Danke Jumpy,

jetzt funktioniert es.

Gruß, Luckner
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: Fehler beim Löschen und Einfügen der Datensätzen.

  Alt 18. Apr 2023, 13:22
Also, ich würde so etwas nicht von der Farbe eines Buttons abhängig machen. Abgesehen davon wäre es bestimmt schöner, im Datenmodul ein paar passende Methoden zu schreiben und die dann von außerhalb nur noch aufzurufen (das spart die gefühlt 100 Stellen von "DataModuleAbhaengikeiten.ZQueryEtiketten_Stanze_G rid.XXX"). Innerhalb dieser Methoden könnte man auch die Queries dynamisch erzeugen (Geschmackssache) und diesen einen parametrisierten SQL-String zuweisen (keine Geschmackssache, sondern alternativlos, sofern man etwas Wert auf Sicherheit legt).
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.298 Beiträge
 
Delphi 12 Athens
 
#6

AW: Fehler beim Löschen und Einfügen der Datensätzen.

  Alt 18. Apr 2023, 13:25
all...
  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 18:13 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