AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Spalten in DBGrid ersetzen
Thema durchsuchen
Ansicht
Themen-Optionen

Spalten in DBGrid ersetzen

Ein Thema von Mysterio08 · begonnen am 28. Feb 2010 · letzter Beitrag vom 28. Feb 2010
Antwort Antwort
Mysterio08

Registriert seit: 11. Jan 2009
142 Beiträge
 
#1

Spalten in DBGrid ersetzen

  Alt 28. Feb 2010, 12:43
Datenbank: BDE • Version: Paradox7 • Zugriff über: Table- und Datasource-Komponente
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
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#2

Re: Spalten in DBGrid ersetzen

  Alt 28. Feb 2010, 13:20
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;
  Mit Zitat antworten Zitat
Mysterio08

Registriert seit: 11. Jan 2009
142 Beiträge
 
#3

Re: Spalten in DBGrid ersetzen

  Alt 28. Feb 2010, 16:57
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.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#4

Re: Spalten in DBGrid ersetzen

  Alt 28. Feb 2010, 16:58
Dann wirst Du um eine Query mit einer entsprechenden SQL-Abfrage wohl nicht herum kommen.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

Re: Spalten in DBGrid ersetzen

  Alt 28. Feb 2010, 17:28
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
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#6

Re: Spalten in DBGrid ersetzen

  Alt 28. Feb 2010, 18:01
Da kann man mal wieder sehen, wie fixiert ich auf SQL bin
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman
Online

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.387 Beiträge
 
Delphi 12 Athens
 
#7

Re: Spalten in DBGrid ersetzen

  Alt 28. Feb 2010, 18:07
...ist auch wesentlich komfortabler
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:26 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