![]() |
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:
Dabei passiert aber Folgendes:
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; - 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 |
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:
und setze es im AfterRefresh wieder
theBookmark:=dsMedia.DataSet.GetBookmark;
Delphi-Quellcode:
theBookmark darf dann nur keine lokale Variabel mehr sein.
dsMedia.DataSet.GotoBookmark(theBookmark);
|
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. |
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 17:25 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz