Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Kann in einem DBGrid eine Tabelle nicht bearbeiten (https://www.delphipraxis.net/48321-kann-einem-dbgrid-eine-tabelle-nicht-bearbeiten.html)

ustra 23. Jun 2005 15:23

Datenbank: MySQL • Version: 4.0.16-nt • Zugriff über: Zeos 6.1

Kann in einem DBGrid eine Tabelle nicht bearbeiten
 
Hallo,

ich habe ein Problem beim Zugriff auf eine Mysql Datenbank mit den ZEOS Komponenten. Folgende Situation: Ich habe auf einem Formular eine ZConnection, ZTable, Dataset und ein DBGrid.

Ich habe in der Mysql Datenbank unter anderem die Datenbanken db1 und db2. Verbinde ich mich mit db1, kann ich problemlos die Tabelle liste im DBGrid bearbeiten, Änderungen werden übernommen.

Verbinde ich mich nun zu db2 - ich ändere nur in der ZConnection die Eigenschaft database und setze conencted auf true und bei ZTable active auf true - , kann ich keine Änderungen in der Tabelle liste2 vornehmen. Ich sehe allerdings alle Daten. Ich bekomme die Meldung "Can not update this query type". Anzumerken ist noch, dass in beiden Tabellen die gleichen Spalten mit den gleichen Datentypen drin stehen.

Ich kann über ein Webfront problemlos auf db2 zugreifen und Daten ändern. Ich habe mittels phpMyAdmin die Rechte aller eingetragenen Benutzer auf "ALL PRIVILEGES" gesetzt. Ich weiss nicht, woran es liegen kann.

Könnt Ihr mir helfen?

Danke
Ulrich

jensw_2000 24. Jun 2005 01:31

Re: Kann in einem DBGrid eine Tabelle nicht bearbeiten
 
Zitat:

"Can not update this query type".
Soll bedeuten, das du deine ZTable mit einem View verbunden hast, in dem ein oder mehrere JOINS mit 1:n, n:n oder SubSelects vorhanden sind.

Diese Datenmengen können nur ReadOnly geöffnet werden, da ein oder mehrere Felder im Datensatz nicht eindeutig bis zum "Datensatz der Quelltabelle" zurückverfolgt werden können. Ein Speichern über TDataset (bzw. Nachfahren) ist somit nicht möglich.

Du musst dein onBeforePost etwa so umbauen:

Procedure TZTable.onBeforePost(bla);
begin
1. Update der Daten in die DB über UpdateSQL, eine Query o.Ä.
2. Dataset.cancel; // Post der ZTable abbrechen
3. ZTable.Refresh; // Daten neu aus den View laden bzw. Refreshen
end;

:hi:

ustra 24. Jun 2005 13:49

Re: Kann in einem DBGrid eine Tabelle nicht bearbeiten
 
Hallo,

so funktioniert es. Allerdings kommt immer noch die Meldung. Daten werden aktualisiert. Ich habe jetzt mit Application.OnException die Meldung unterdrückt, obwohl das eigentlich noch nicht richtig sauber ist.

Danke für die Hilfe.

Ulrich


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