![]() |
Datenbank: advantage databaser server • Version: 9 • Zugriff über: ads
DBGrid - 2 Zeilen gleichzeitig bearbeiten
Hi,
folgendes Problem: Ich habe ein DBGrid mit X Datensätzen. Nun will ich per Klick auf einen Button einen neune Datensatz erzeugen und mit einem Timer einem Feld immer eine Sekunde hinzuaddieren. Soweit kein Problem, allerdings brauche ich jetzt die möglichkeit, während der eine Datensatz am hochzählen ist, einen anderen Datensatz auswählen und bearbeiten zu können. Das sollte ja mit ClientDataSets machbar sein. Ich habe jetzt folgenden Aufbau: TQuery DataSetProvider (angeschlossen an TQuery) ClientDataSet1 (angeschlossen an DataSetProvider) ClientDataSet2Klon (auch angeschlossen an DataSetProvider) Datasource1 (angeschlossen an ClientDataSet1) DBGrid (angeschlossen an Datasource1) DBEdit (auch angeschlossen an Datasource1) Nun einen Button, bei dem ich onClick einen Datensatz ans ClientDataSet1 anfüge und anschließend einen Timer starte, der ein Feld von ClientDataSet1 laufend aktualisiert. Soweit geht das schonmal. Wenn ich nun im dbGrid einen andren Datensatz auswähle, läuft der Timer auch weiter und ich kriege im DBEdit den Text des jetzt ausgewählten Datensatzes angezeigt. Das Problem: Soblad im DBEdit anfange den Text zu ändern (und somit in den edit mode gelange), wird das Feld das im Timer aktualisiert wird nicht mehr aktualisiert. Wenn ich jetzt wieder einen anderen Datensatz im DBGrid auswähle, läuft die aktualisierung wieder weiter. Kann mir da jemand einen Tip geben? PS: Evt. könnte man im onChange des EditFields ständig ein "ClientDataSet1.Post" machen, aber ist das eine gute lösung? |
AW: DBGrid - 2 Zeilen gleichzeitig bearbeiten
Also zunächst mal sind deine Anforderungen etwas seltsam.
Weshalb soll sich timergesteuert ein Feld in einer Tabelle pemanent ändern? Das erscheint mir unsinnig; es ist nicht Sinn und Zweck einen Datenbank temporäre Daten zu speichern oder zusammen mit einem DBGrid als Anzeige misbraucht zu werden. Aber sei's drum. Angenommen du bist im Editiervorgang und "parallel" soll ein anderen Datensatz geändert werden. 1.) Alle Felder des aktuellen, editierten Datensatz zwischenspeichern
Delphi-Quellcode:
2.) Cancel aufrufen; damit werden die aktuellen Änderungen verworfen
var
Data : array of variant; aRecord : array of TVarRec; i : integer; max : integer; begin max := aDataSet.fields.count -1; // set the lenghth of the arecord array to be the same as the number of // elements in the data array SetLength(arecord,max+1); SetLength(data,max+1); // set the variant type pointers to the data array for i := 0 to max do begin arecord[i].VType := vtVariant; arecord[i].VVariant := @data[i]; end; // Copy the Record to the Array for i := 0 to max do Data[i] := aDataSet.fields[i].value; 3.) Datensatz wechseln (mit Locate) und ändern 4.) wieder zurück auf den zu editierenden Datensatz (mit Locate) 5.) mit Edit in den Editiermodus gehen 6.) und zwischengespeicherte Daten schreiben
Delphi-Quellcode:
Im Prinzip wäre das so möglich, aber das DbGrid verliert dabei den Focus und die Cursorposition des aktuellen Feldes.
DataSet.SetFields(aRecord);
Also ich würde raten, die Sache völlig anderst zu lösen. |
AW: DBGrid - 2 Zeilen gleichzeitig bearbeiten
Hi und danke für deine Antwort.
ich habe eine Tabelle in der ein und ausgehende anrufe gespeichert werden. Wenn nun ein neuer anruf reinkommt, wird ein neuer Datensatz angelegt und die Dauer des Telefonats wird in einem der Felder angezeigt und soll sekündlich geupdated werden. Gleichzeitig soll ein bereits bestehender Datensatz ausgewählt werden können und in einem Textfeld dazu weitere Informationen angezeigt / geändert werden können. Die anforderung habe ich mir nicht ausgedacht, der Kunde will es so haben und ich habe da nichts zu entscheiden. Wenns nach mir ginge wäre das anders aufgebaut. |
AW: DBGrid - 2 Zeilen gleichzeitig bearbeiten
kannst Du nicht zwei Table-Komponenten verwenden? Durch das sekündliche Refresh der ersten bekommst Du dann auch gepostete Daten der zweiten angezeigt.
|
AW: DBGrid - 2 Zeilen gleichzeitig bearbeiten
Ich würde statt eines DBGrid ein normales Stringgrid verwenden, damit bist Du wesentlich flexibler. Einen Datensatz schon beim Beginn des Telefonats in die Datenbank zu schreiben und dann jede Sekunde die Dauer zu aktualisieren, ist eigentlich Unfug. Mit einem normalen DBGrid kannst Du den Datensatz in die Datenbank schreiben, wenn das Telefonat abgeschlossen und die Dauer bekannt ist, aber den Satz schon vorher im Grid anzeigen.
Eine andere Möglichkeit dazu: Dauer bei Start (=0) und Ende des Gesprächs speichern, und die aktuelle Gesprächsdauer manuell über das Gridfeld drüber"zeichnen". |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:05 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