Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   dbnavigator nbRefresh überschreiben (https://www.delphipraxis.net/191787-dbnavigator-nbrefresh-ueberschreiben.html)

Siggi 19. Feb 2017 18:45

Datenbank: friebird • Version: 2 • Zugriff über: Zeos

dbnavigator nbRefresh überschreiben
 
Hi,

ich habe in Delphi 2010 eine DBNavigator-Komponente auf dem Formular.

Nun kann es ja vorkommen, dass ein Datensatz im Formular geladen wird und datenbankseitig währenddessen etwas verändert wird. Daher ist in der DBNavigator-Komponente auch der nbRefresh-Button klickbar (ja, wenn man den nicht anklickt bekommt man die Änderung auch nicht nicht mit, aber das ist ein anders Thema).

Mein Verständnisproblem ist nun folgendes:
- ich lade den Datensatz
- ich ändere per SQL nebenher etwas an diesem Datensatz, so dass es die Applikation erst mal nicht mitbekommt
- ich licke auf nbRefresh um die aktualisierten Daten zu laden

Delphi lädt die Daten neu, springt aber zum ersten Datensatz der query. Blättere ich zum geänderten Datensatz ist dort alles OK. Störend ist nur der Sprung zum ersten Datensatz.

Nichts leichter als das, dachte ich, und habe die folgende Procedure erstellt:

Delphi-Quellcode:
procedure TfrmMedia.sDBNavigator1Click(Sender: TObject; Button: TNavigateBtn);
Var
  theBookmark: TBookmark;
begin
  case Button of
    nbRefresh:
      begin
        theBookmark:=dsMedia.DataSet.GetBookmark;
        dsMedia.DataSet.Refresh;
        dsMedia.DataSet.GotoBookmark(theBookmark);
      end;
  end;
end;
Dabei passiert aber Folgendes:
- theBookmark wird gefüllt
- DataSet.refresh wird ausgeführt
- GotoBookmark wird ausgeführt (allerdings scheint dabei irgendetwas ungewolltes zu passieren, denn danach folgender Code (testweise mal ein abort eingefügt) wird nicht ausgeführt)
- es wird aber anschließend die normale Behandlung für nbRefresh ausgeführt und Delphi springt wieder zum ersten Datensatz :-(

Wo ist hier mein Denkfehler?

Stehe auf dem Schlauch :-(. Vielen Dank für alle Tipps die mich da runter schubsen...

Siggi

nahpets 19. Feb 2017 19:53

AW: dbnavigator nbRefresh überschreiben
 
Sagen wir mal so: Du rufst in der Routine Refresh auf und der Button ruft Refresh auf, es wird also zwei mal ausgeführt.

Die Datenbankkomponente müsste eigentlich über die Ereignisse BeforeRefresh und AfterRefresh verfügen.

Merke Dir im BeforeRefresh
Delphi-Quellcode:
theBookmark:=dsMedia.DataSet.GetBookmark;
und setze es im AfterRefresh wieder
Delphi-Quellcode:
dsMedia.DataSet.GotoBookmark(theBookmark);
theBookmark darf dann nur keine lokale Variabel mehr sein.

mensch72 19. Feb 2017 20:08

AW: dbnavigator nbRefresh überschreiben
 
damit es nicht in den DB Controls zu sehr "flackert", könnte man im "BeforeEvent" die GUI Updates abschalten und im "AfterEvent" wieder einschalten

für Einfachanwendungen reicht das Verfahren anfangs so, besser wird es wenn man nur mit eigenen Programmen (verteilt)auf die DB zugreift und entweder deren MessageFunktionalität nutzt, bzw. im einfachsten Fall sich mit eigen z.B. UDP Broadcast-Infos im Netzwerk behilft.

Verteilte MultipleRead/SingleWrite Logik mit TimeOuts, wenn jemand seinen Datensatz doch nicht in definierter Zeit wieder frei gibt... das erfordert aber noch ein paar mehr Codezeilen.

Siggi 19. Feb 2017 20:26

AW: dbnavigator nbRefresh überschreiben
 
@nahpets: funktioniert wunderbar. Danke, dann kann ich mich nun um die größeren Themen kümmern ohne dauernd wegen so einer Kleinigkeit gedanklich blockiert zu sein :-)

Siggi


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:42 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