Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi MyBase: Datenlöschen (https://www.delphipraxis.net/181462-mybase-datenloeschen.html)

Kralle 18. Aug 2014 09:42

Datenbank: MyBase • Version: x • Zugriff über: x

MyBase: Datenlöschen
 
Moin,

entweder sehe ich den Wald vor lauter Bäumen nicht oder bin total auf dem Holzweg.

Gebene ist folgender Code:
Code:
begin
   BtDatensatzLoeschen.Caption:=IntToStr(ClientDataSet1.RecordCount); // Anzahl der Einträge in der Datenbank
   for I := 1 to ClientDataSet1.RecordCount do
     Begin
       If ClientDataSet1.Locate('Codenummer',lbledt1.text,[]) then // Datensatz finden
         begin
          ClientDataSet1.edit; // Datenbank zum Bearbeiten öffnen
           ClientDataSet1.delete; // Datensatz löschen
           ClientDataSet1.Post; // Datenbank aktualisieren
         end;
     End;
end;

procedure TForm1.BtStatusAendernClick(Sender: TObject);
begin
   If ClientDataSet1.Locate('ID','3',[]) then // Datensatz finden
     if ClientDataSet1['Status'] ='0' then
       begin
         ClientDataSet1.edit; // Datenbank zum Bearbeiten öffnen
         ClientDataSet1['Status']:='1'; // Inhalt ändern
         ClientDataSet1.Post; // Datenbank aktualisieren
       end
     else
     begin
         ClientDataSet1.edit; // Datenbank zum Bearbeiten öffnen
         ClientDataSet1['Status']:='0'; // Inhalt ändern
         ClientDataSet1.Post; // Datenbank aktualisieren
     end;
 end;
Der untere Teil funktioniert wie gewünscht, aber der obere Teil führt zur folgenden Fehlermeldung:
Zitat:

Erste Gelegenheit für Exception bei $00007FFA23B25BF8. Exception-Klasse EDatabaseError mit Meldung 'ClientDataSet1: Datenmenge weder im Editier- noch im Einfügemodus'. Prozess mybase_test.exe (404)
Aber, ich habe doch ein
Code:
ClientDataSet1.edit; // Datenbank zum Bearbeiten öffnen
im Code.
Was mache ich falsch??

Gruß Heiko

Jasocul 18. Aug 2014 10:03

AW: MyBase: Datenlöschen
 
Benutze zukünftig den Debugger, damit du siehst, wo der Fehler passiert. Vielleicht wärest du dann selbst auf die richtige Idee gekommen.

Der Fehler dürfte durch dein "ClientDataSet1.Post" entstehen.

Das ClientDataSet1.Edit ist völlig überflüssig. Du setzt damit den Datensatz, den du löschen willst in den Edit-Modus. Danach löscht du diesen dann. Ich wäre nicht mal auf die Idee gekommen, das so zu machen und hätte eher vermutet, dass dort eine Exception auftritt.

Und für ClientDataSet1.Delete benötigst du kein ClientDataSet1.Post. Das Post ist nur für neue Datensätze oder Datensätze, die geändert werden.

Kralle 18. Aug 2014 10:50

AW: MyBase: Datenlöschen
 
Hallo Jasocul,

Zitat:

Zitat von Jasocul (Beitrag 1268931)
Benutze zukünftig den Debugger, damit du siehst, wo der Fehler passiert. Vielleicht wärest du dann selbst auf die richtige Idee gekommen.

Als ich versucht habe mittels Breakpoint und F7 durch den Quellcode zu laufen um zu sehen wo der Fehler genau auftritt, fuktionierte das natürlich mal wieder nicht.
Zitat:

Zitat von Jasocul (Beitrag 1268931)
Der Fehler dürfte durch dein "ClientDataSet1.Post" entstehen.

Jupp, das war es.
Zitat:

Zitat von Jasocul (Beitrag 1268931)
Das ClientDataSet1.Edit ist völlig überflüssig. Du setzt damit den Datensatz, den du löschen willst in den Edit-Modus. Danach löscht du diesen dann. Ich wäre nicht mal auf die Idee gekommen, das so zu machen und hätte eher vermutet, dass dort eine Exception auftritt.

Da ein Schrittweises abarbeiten mal wieder nicht funktioniert hat und es in der Fehlermeldung hies:
Zitat:

Datenmenge weder im Editier- noch im Einfügemodus'
dachte ich mir:"Da haste wohl das "Edit" vergessen."
Zitat:

Zitat von Jasocul (Beitrag 1268931)
Und für ClientDataSet1.Delete benötigst du kein ClientDataSet1.Post. Das Post ist nur für neue Datensätze oder Datensätze, die geändert werden.

okay, das habe ich mir jetzt notiert.

Danke.

Gruß HEiko

Jumpy 18. Aug 2014 10:54

AW: MyBase: Datenlöschen
 
Ich verstehe nur nicht ganz, warum du für das Löschen eines Datensatzes in einer Schleife durch die ganze Datenmenge läufst? Dafür hast du doch Locate?

Kralle 18. Aug 2014 10:58

AW: MyBase: Datenlöschen
 
Moin,

Zitat:

Zitat von Jumpy (Beitrag 1268949)
Ich verstehe nur nicht ganz, warum du für das Löschen eines Datensatzes in einer Schleife durch die ganze Datenmenge läufst? Dafür hast du doch Locate?

Ich will aber nicht nur einen Datensatz löschen sondern alle mit einem bestimmten Wert in "Codenummer".

Gruß HEiko

mkinzler 18. Aug 2014 11:02

AW: MyBase: Datenlöschen
 
Trotzdem kannst Du dich dann auf die Datensätze, die dem Suchmuster entsprechen, beschränken (Z.B. per Locate)

Jumpy 18. Aug 2014 11:03

AW: MyBase: Datenlöschen
 
ok. Dann würde ich aber mit einer while Schleife arbeiten:

while ClientDataset1.Locate(...) do
ClientDataset1.Delete

oder so.

Oder natürlich ein entsprechendes SQL-Statement absetzen (um alle entsprehcende Datensätze auf einmal zu löschen) und danach das ClientDataset aktualisieren.

DeddyH 18. Aug 2014 11:04

AW: MyBase: Datenlöschen
 
Das würde ich vielleicht eher so angehen (Pseudo-Code):
Delphi-Quellcode:
Dataset.First;
while not Dataset.EOF do
  begin
    if Dataset.FieldByName['Codenummer'] = DeinSuchbegriff then
      Dataset.Delete
    else
      Dataset.Next;
  end;
SQL o.ä. scheidet bei MyBase ja leider aus.

Jumpy 18. Aug 2014 11:17

AW: MyBase: Datenlöschen
 
Zitat:

Zitat von DeddyH (Beitrag 1268954)
SQL o.ä. scheidet bei MyBase ja leider aus.

Das wußte ich nicht und nehme meinen obigen Vorschlag wieder zurück. :oops:

Kralle 18. Aug 2014 11:52

AW: MyBase: Datenlöschen
 
Danke, für Eure Hilfe.

Die "Schleife " habe ich jetzt so gelöst:
Code:
with ClientDataSet1 do
   begin
     First;
     while not EOF do
       begin
         if FieldByName('Codenummer').AsString = lbledt1.text then
           Delete
         else
           Next;
       end;
   end;
Oder spricht was gehen "with"?

Gruß Heiko


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:59 Uhr.
Seite 1 von 3  1 23      

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