Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   DBGrid - 2 Zeilen gleichzeitig bearbeiten (https://www.delphipraxis.net/152642-dbgrid-2-zeilen-gleichzeitig-bearbeiten.html)

bwolf 30. Jun 2010 13:39

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?

shmia 30. Jun 2010 14:23

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:
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;
2.) Cancel aufrufen; damit werden die aktuellen Änderungen verworfen
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:
DataSet.SetFields(aRecord);
Im Prinzip wäre das so möglich, aber das DbGrid verliert dabei den Focus und die Cursorposition des aktuellen Feldes.
Also ich würde raten, die Sache völlig anderst zu lösen.

bwolf 30. Jun 2010 14:34

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.

joachimd 30. Jun 2010 15:02

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.

idefix2 1. Jul 2010 08:13

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