![]() |
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 |
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 |
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. |
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 |
Re: DBGrid manipulieren
Zitat:
Delphi-Quellcode:
So in der Art... das Feld MeineCDNr ist dein berechnetes Feld.
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 ; |
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 10:30 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