Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Spalten in DBGrid ersetzen (https://www.delphipraxis.net/148355-spalten-dbgrid-ersetzen.html)

Mysterio08 28. Feb 2010 11:43

Datenbank: BDE • Version: Paradox7 • Zugriff über: Table- und Datasource-Komponente

Spalten in DBGrid ersetzen
 
Guten Tag,

ich habe mich jetzt auf in die riesige Welt der Datenbanken, welche Delphi bietet, begeben. Sehr weit bin ich noch nicht gekommen, ein Problem ist trotzdem schon aufgetaucht:
Ich habe ein aus drei Tabellen bestehendes relationales Datenbankmodell; die Master-Tabelle wird in einem DBGrid angezeigt, also (leider) auch Felder wie u.a. LagerortID, AutorID, die aus kryptischen Zahlen-/Buchstabenkombinationen bestehen. Ich würde es gerne so handhaben, dass diese Spalten nicht über den Objektinspektor auszublenden/zu löschen sind, was ich hinbekommen habe, sondern mit den Lager- bzw. Autorenbezeichnungen zu ersetzen sind.
Das Problem ist ja, dass ich bei dem DBGrid immer nur eine Tabelle angeben, also diese Felder (Autor, Lagerort) in den Spalten nicht auswählen, kann.
Muss ich jetzt mit SQL-Abfragen arbeiten oder gibt es noch eine andere, evtl. einfachere Variante?

mfg. Mysterio08

sx2008 28. Feb 2010 12:20

Re: Spalten in DBGrid ersetzen
 
Wenn du bestimmte Spalten unsichtbar machen möchtest, dann kannst du das z.B. so tun:
Delphi-Quellcode:
peocedure TForm1.Table1AfterOpen(Dataset:TDataset);
begin
  Dataset.FieldByName('IdLager').Visible := False;
end;
Um einem Feld einen lesbaren Namen zu geben:
Delphi-Quellcode:
peocedure TForm1.Table1AfterOpen(Dataset:TDataset);
begin
  Dataset.FieldByName('BrWert').DisplayLabel := 'Bruttowert (€)';
end;

Mysterio08 28. Feb 2010 15:57

Re: Spalten in DBGrid ersetzen
 
Zitat:

Zitat von sx2008
Um einem Feld einen lesbaren Namen zu geben:
Delphi-Quellcode:
peocedure TForm1.Table1AfterOpen(Dataset:TDataset);
begin
  Dataset.FieldByName('BrWert').DisplayLabel := 'Bruttowert (€)';
end;

Danke, aber das ist noch nicht genau das, was ich suche, denn ich könnte das ja auch im Objektinspektor machen.
Ich suche eine Möglichkeit, wie sich nicht nur die Überschrift der Spalte sondern auch die Inhalte ändern.

Ich erkläre das mal ein wenig ausführlicher: ich habe eine Mastertabelle, von welcher sich DBGrid die Daten holt. Ein Feld beinhaltet die Autoren-ID von Bücher. Ich möchte aber nicht irgendwelche kryptischen Zahlen-/Buchstabenkombinationen sehen sondern vielmehr die Autorennamen, die sich in einer anderen Tabelle befinden.

DeddyH 28. Feb 2010 15:58

Re: Spalten in DBGrid ersetzen
 
Dann wirst Du um eine Query mit einer entsprechenden SQL-Abfrage wohl nicht herum kommen.

Sir Rufo 28. Feb 2010 16:28

Re: Spalten in DBGrid ersetzen
 
Das geht aber auch über LookUp-Felder.

Rechtsklick auf das Table-Objekt und dann Feld-Editor.

Dort kannst du einen neues Feld hinzufügen und kannst dort angeben, dass der Wert "nachgeschlagen" werden soll

DeddyH 28. Feb 2010 17:01

Re: Spalten in DBGrid ersetzen
 
Da kann man mal wieder sehen, wie fixiert ich auf SQL bin :mrgreen:

haentschman 28. Feb 2010 17:07

Re: Spalten in DBGrid ersetzen
 
...ist auch wesentlich komfortabler :zwinker:


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