Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi DBGrid manipulieren (https://www.delphipraxis.net/30004-dbgrid-manipulieren.html)

fkerber 18. Sep 2004 07:54


DBGrid manipulieren
 
Hi!

Ich habe folgendes Problem, zu dem ich im Forum keine Lösung gefunden habe.
Ich verwende die Absoulte Database und lasse die Daten in einem DBGrid anzeigen.

Es gibt folgende Spalten:
Titel, Interpret, Tanz, TPM, Bewerung, CD-Nr., Track-Nr., Dauer
(in dieser Reihenfolge)

Da jede CD nur eine Nummer hat, musste ich mir für DoppelCDs etwas einfallen lassen.
Also dachte ich mir, ich setze da immer ne 100 davor. (Also Lied 10 von CD 2 hat die Nummer 110)

Dann sollte es bei der Ausgabe so sein, dass geguckt wird, ob die Tracknr. > 100 ist.

Falls ja, sollte hinter die CD-Nummer eine "-2" und die Tracknummer sollte um 100 verringert werden.

Und mir fehlt jetzt jeglicher Ansatz.

Danke für euer Hilfe.

Ciao Frederic

Jelly 18. Sep 2004 08:22

Re: DBGrid manipulieren
 
Arbeite doch mit CalculatedField... Füllen kannst du diese Felder dann im OnCalcFields Event deines Datasets. Ein neues Feld erzeugen mit DoppelKlick auf die Dataset-Komponente und anschliessend ein neues Feld hinzufügen... Die Felder kannst du natürlich vom Benutzer nicht ändern lassen, aber lesend kannst du auf sie zugreifen wie normale Felder.

Gruß,
Tom

Sharky 18. Sep 2004 08:27

Re: DBGrid manipulieren
 
Hai Fredric,

alternativ könntest Du überlegen auf das DB-Grid zu verzichten und deine Daten in einer TListView anzuzeigen. Ich selber mache das fast nur noch so. Damit bin ich zwar gezwungen mich selber darum zu kümmern die Anzeige zu aktualisieren wenn sich ein Datensatz geändert hat aber dafür habe ich wesentlich mehr Freiheiten bei der Anzeige der Daten.

fkerber 18. Sep 2004 08:43

Re: DBGrid manipulieren
 
Hi!

@Tom:
Kannst du mir deine Idee etwas näher erklären? Ich blick da noch nicht ganz durch, was ich da wo machen soll.
Muss ich da alle Felder hinzufügen und wie geht es dann weiter?

@Stephan:
Danke für die Idee, aber ich bleibe vorläufig der Einfachheit halber mal beim DBGrid. Wenns dann irgendwann gar nicht mehr geht, komme ich ja vielleicht auch zu Listview.


Ciao Frederic

Jelly 18. Sep 2004 08:53

Re: DBGrid manipulieren
 
Zitat:

Zitat von fkerber
und wie geht es dann weiter?

Dann setzt du noch ein einzelnes Feld hinzu, und verpasst dem den nötigen Datentyp, und eben das Attribut Calculated Fields. Im OnCalcFields-Event dann sowas wie das hier:
Delphi-Quellcode:
begin
   with Dataset do begin
      if FieldByName ('Track').AsInteger > 100
      then FieldByName ('MeineCDNr').AsString := inttostr(FieldByName ('Track').AsInteger - 100) + '-2'
      else FieldByName ('MeineCDNr').AsString := inttostr(FieldByName ('Track').AsInteger) ;
   end ;
end ;
So in der Art... das Feld MeineCDNr ist dein berechnetes Feld.

fkerber 18. Sep 2004 16:53

Re: DBGrid manipulieren
 
Hi!

Ich schau es mir mal an.
Danke für deine Mühe.

Ciao Frederic


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