AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Multidelete im cxGrid
Thema durchsuchen
Ansicht
Themen-Optionen

Multidelete im cxGrid

Ein Thema von Morphie · begonnen am 17. Jan 2009 · letzter Beitrag vom 18. Jan 2009
Antwort Antwort
Morphie

Registriert seit: 27. Apr 2008
Ort: Rahden
630 Beiträge
 
#1

Multidelete im cxGrid

  Alt 17. Jan 2009, 10:24
Datenbank: Firebird • Version: 2 • Zugriff über: devart's IBDAC
Morgen liebe DPler! =)

Ich weiß nicht, ob ich hier richtig bin, hoffe aber mal schon

Zu meinem Problem:
Ich versuche mit dem cxGrid eine Art Multidelete durchzuführen. Also alle markierten Datensätze sollen gelöscht werden...

Mein code dazu sieht wie folgt aus:
Delphi-Quellcode:
procedure Tkunden.LoeschenExecute(Sender: TObject);
var
i: integer;
bm: TBookmarkStr;
begin
  for i := 0 to GridDBTableView1.Controller.SelectedRecordCount-1 do
  begin
    bm:=GridDBTableView1.DataController.GetSelectedBookmark(i);
    queryKundenliste.Bookmark:=bm;
    queryKundenliste.Delete;
  end;
end;
Jetzt bekomme ich aber immer folgende Fehlermeldung:
---------------------------
Benachrichtigung über Debugger-Exception
---------------------------
Im Projekt test.exe ist eine Exception der Klasse EcxInvalidDataControllerOperation mit der Meldung 'DataController not in GridMode' aufgetreten.
---------------------------
Anhalten Fortsetzen Hilfe
---------------------------


Der DataController soll aber auch nicht im GridMode arbeiten.
Gibt es dafür irgend eine Lösung?
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#2

Re: Multidelete im cxGrid

  Alt 17. Jan 2009, 10:53
Zitat von Morphie:
Ich versuche mit dem cxGrid eine Art Multidelete durchzuführen. Also alle markierten Datensätze sollen gelöscht werden...

Mein code dazu sieht wie folgt aus:
Delphi-Quellcode:
procedure Tkunden.LoeschenExecute(Sender: TObject);
var
i: integer;
bm: TBookmarkStr;
begin
  for i := 0 to GridDBTableView1.Controller.SelectedRecordCount-1 do
  begin
    bm:=GridDBTableView1.DataController.GetSelectedBookmark(i);
    queryKundenliste.Bookmark:=bm;
    queryKundenliste.Delete;
  end;
end;
Jetzt bekomme ich aber immer folgende Fehlermeldung:
---------------------------
Benachrichtigung über Debugger-Exception
---------------------------
Im Projekt test.exe ist eine Exception der Klasse EcxInvalidDataControllerOperation mit der Meldung 'DataController not in GridMode' aufgetreten.
---------------------------
Anhalten Fortsetzen Hilfe
---------------------------


Der DataController soll aber auch nicht im GridMode arbeiten.
In diesem Fall würde ich alle markierten Sätze durchlaufen, die Werte der Primary Keys auslesen und jeweils ein SQL Delete Statement an die Datenbank senden. Wenn Konsistenz wichtig ist, natürlich in einer Transaktion, für den Fall dass ein Satz sich nicht löschen lässt.

Im DevExpress Forum gibt es Beispielsource, wie man die markierten Sätze durchläuft ohne dabei auf die verbundene Query zuzugreifen (die Daten stehen ja schon im Grid).
Michael Justin
habarisoft.com
  Mit Zitat antworten Zitat
Morphie

Registriert seit: 27. Apr 2008
Ort: Rahden
630 Beiträge
 
#3

Re: Multidelete im cxGrid

  Alt 18. Jan 2009, 19:13
Für alle, die das gleiche Problem haben:

Delphi-Quellcode:
procedure Tkunden.LoeschenExecute(Sender: TObject);
begin
  GridDBTableView1.Controller.DeleteSelection;
end;
so einfach kanns sein
  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 04:41 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