Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi DBGrid + DBNavigator: Post/Commit wird nicht akzeptiert (https://www.delphipraxis.net/172871-dbgrid-dbnavigator-post-commit-wird-nicht-akzeptiert.html)

messie 26. Jan 2013 16:08

Datenbank: Firebird • Version: 2,5 • Zugriff über: IBDAC

DBGrid + DBNavigator: Post/Commit wird nicht akzeptiert
 
Moin,

die Posts aus der Suche haben mir nicht wirklich geholfen. Ich zeige eine Datenmenge aus einer Query im Grid an und möchte das mit dem Navigator editieren. Im Edit-Modus geht es aber die Eingaben kommen nicht in der DB an. Der Post-Button scheint die Datenmenge (DataSource) zu verändern, es wird aber nicht in die DB übernommen. Dazu muss ich jetzt per Extra-Button ein commit senden.
Es gibt auch noch den Button nbApplyUpdates aber der ist ausgegraut.

Geht das auch anders bzw. wie bekomme ich nbApplyUpdates enabled falls das der richtige ist?

Danke, Messie

mkinzler 26. Jan 2013 16:11

AW: DBGrid + DBNavogator: Post/Commit wird nicht akzeptiert
 
Wenn die Tranaktion sofort comittet werden soll, könntest du AutoCommit konfigurieren

messie 26. Jan 2013 20:16

AW: DBGrid + DBNavogator: Post/Commit wird nicht akzeptiert
 
Zitat:

Zitat von mkinzler (Beitrag 1200717)
Wenn die Transaction sofort comittet werden soll, könntest du AutoCommit konfigurieren

Das hatte ich auch so erwartet, hat aber leider nicht die erhoffte Wirkung. Im Moment baue ich an der DefaultCloseAction der Transaction rum. Die habe ich auf taCommit gesetzt, damit kann ich neue Einträge in die DB übertragen. Beim Löschen brauche ich wieder ein Hardcommit, was die Transaction tatsächlich schließt. :gruebel:

Im Moment habe ich mein DBGrid, in dem der User Bearbeitungsmöglichkeiten haben soll. Dazu habe ich eine Query, eine Transaction und eine DataSource.

Gibt es evtl. eine Doku von Befehlen mit der ich das Grid in den Bearbeitungsmodus bringen kann, Datensätze verändern, hinzufügen und entfernen kann und das dann speichern? Also die Funktionen "zu Fuß" abarbeiten? Mir fehlt noch ein wenig die Leichtfüßigkeit im Thema. :-D
Mir ist z.B. nicht klar, wem ich einen Datensatz hinzufügen müsste, damit im DBGrid eine neue leere Zeile erscheint.

Grüße, Messie

Perlsau 26. Jan 2013 21:58

AW: DBGrid + DBNavogator: Post/Commit wird nicht akzeptiert
 
Zitat:

Zitat von messie (Beitrag 1200742)
Gibt es evtl. eine Doku von Befehlen mit der ich das Grid in den Bearbeitungsmodus bringen kann, Datensätze verändern, hinzufügen und entfernen kann und das dann speichern? Also die Funktionen "zu Fuß" abarbeiten? Mir fehlt noch ein wenig die Leichtfüßigkeit im Thema. :-D

Es gibt keinen speziellen Bearbeitungsmodus für ein DBGrid. Du kannst in den Options des DBGrid das Property dgEditing auf True stellen, dann kann der Anwender jederzeit Daten im DBGrid ändern. Dazu benötigst du auch keinen DBNavigator, denn das Query, das die Daten für dein DBGrid liefert, geht automatisch in den Edit-Modus, wenn der Anwender beginnt, eine Zelle zu bearbeiten. Cancel wird hier durch die ESC-Taste ausgelöst, Post durch die Enter-Taste.

Zitat:

Zitat von messie (Beitrag 1200742)
Mir ist z.B. nicht klar, wem ich einen Datensatz hinzufügen müsste, damit im DBGrid eine neue leere Zeile erscheint.

Du meintest sicherlich, dir sei nicht klar, wie du via DBGrid einen neuen Datensatz anlegst. Das funktioniert ganz einfach, vorausgesetzt dgEditing steht auf True: Drücke die Einfüge-Taste oder, wenn der Cursor ganz am Ende der Tabelle steht, drücke die Cursor-Nach-Unten-Taste. In beiden Fällen wird ein neuer leerer Datensatz erzeugt. Mit ESC wird diese Erzeugung wieder zurückgenommen (Rollback), mit Enter bestätigt.

messie 27. Jan 2013 09:28

AW: DBGrid + DBNavogator: Post/Commit wird nicht akzeptiert
 
Zitat:

Zitat von Perlsau (Beitrag 1200759)
Du meintest sicherlich, dir sei nicht klar, wie du via DBGrid einen neuen Datensatz anlegst. Das funktioniert ganz einfach, vorausgesetzt dgEditing steht auf True: Drücke die Einfüge-Taste oder, wenn der Cursor ganz am Ende der Tabelle steht, drücke die Cursor-Nach-Unten-Taste. In beiden Fällen wird ein neuer leerer Datensatz erzeugt. Mit ESC wird diese Erzeugung wieder zurückgenommen (Rollback), mit Enter bestätigt.

Ja, aber das betrifft nur die Datenmenge im Grid, in der Tabelle kommt das erst an wenn ich noch ein extra commit sende.

Gibt es einen Befehl wie "neue Zeile" oder ein event was daran gekoppelt ist? Ich habe noch eine andere verbundene Tabelle und bei einer neuen Zeile würde ich gerne den Verweis in der zweiten Tabelle anlegen.

Grüße, Messie

mkinzler 27. Jan 2013 09:34

AW: DBGrid + DBNavigator: Post/Commit wird nicht akzeptiert
 
Ich würde hier eher das DataSet überwachen

Perlsau 27. Jan 2013 09:35

AW: DBGrid + DBNavogator: Post/Commit wird nicht akzeptiert
 
Zitat:

Zitat von messie (Beitrag 1200810)
Ja, aber das betrifft nur die Datenmenge im Grid, in der Tabelle kommt das erst an wenn ich noch ein extra commit sende.

Das DBGrid hat keine Datenmenge, sondern dient nur der Anzeige der Datenmenge eines Datasets bzw. Queries. Allerdings kannst du, wie oben beschrieben, mit dem DBGrid in gewisser Weise Einfluß auf das Dataset ausüben.

Zitat:

Zitat von messie (Beitrag 1200810)
Gibt es einen Befehl wie "neue Zeile" oder ein event was daran gekoppelt ist? Ich habe noch eine andere verbundene Tabelle und bei einer neuen Zeile würde ich gerne den Verweis in der zweiten Tabelle anlegen.

Der Befehl für eine neue Zeile heißt Insert bzw. Append. Wenn du das via Buttons lösen willst, machst du dir am besten ein Panel mit den benötigten Buttons und schreibst in deren Execute-Procedure die entsprechenden Sachen rein. So kannst du z.B. das DBGrid grundsätzlich uneditierbar halten und erst zum editeren freigeben, wenn der Benutzer vorher auf den Edit-Button gedrückt hat. Damit verbindest du dann eine Anzeige z.B. in der Statusbar, die z.B. von Browse-Modus in Edit-Modus wechselt, damit der Anwender weiß, daß er jetzt erhöhte Vorsicht walten lassen muß, weil er am Editieren ist.

messie 27. Jan 2013 20:31

AW: DBGrid + DBNavogator: Post/Commit wird nicht akzeptiert
 
Zitat:

Zitat von Perlsau (Beitrag 1200813)
Wenn du das via Buttons lösen willst, machst du dir am besten ein Panel mit den benötigten Buttons und schreibst in deren Execute-Procedure die entsprechenden Sachen rein. So kannst du z.B. das DBGrid grundsätzlich uneditierbar halten und erst zum editeren freigeben, wenn der Benutzer vorher auf den Edit-Button gedrückt hat. Damit verbindest du dann eine Anzeige z.B. in der Statusbar, die z.B. von Browse-Modus in Edit-Modus wechselt, damit der Anwender weiß, daß er jetzt erhöhte Vorsicht walten lassen muß, weil er am Editieren ist.

Ich bin einen Schritt weiter gegangen und habe die Grids uneditierbar gehalten und alles über ein Extrafenster gelöst. Also alles "zu Fuß". So ist es sicher und die Funktionen für das Speichern in die DB hatte ich schon.

Danke für die Tipps, Messie

Leonardus 29. Jan 2013 13:32

AW: DBGrid + DBNavigator: Post/Commit wird nicht akzeptiert
 
Vielleicht ist hier, was Sie wollen.
http://www.delphi-treff.de/tutorials...e/einfuehrung/


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