![]() |
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 |
Re: Kann in einem DBGrid eine Tabelle nicht bearbeiten
Zitat:
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: |
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 23:14 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-2025 by Thomas Breitkreuz