AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Daten im DBGrid für Anzeigezwecke manipulieren
Thema durchsuchen
Ansicht
Themen-Optionen

Daten im DBGrid für Anzeigezwecke manipulieren

Ein Thema von Tempdir · begonnen am 23. Apr 2009 · letzter Beitrag vom 23. Apr 2009
Antwort Antwort
Tempdir

Registriert seit: 19. Feb 2009
Ort: Karlsruhe
84 Beiträge
 
RAD-Studio 2009 Pro
 
#1

Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 10:05
Datenbank: TurboDB • Version: 5.16 • Zugriff über: TDB-Komponenten
Hallo,

ich habe eine TDBQuery-Komponente die auf eine Datenbank zugreift (z.B. SELECT * FROM tabelle). Über eine Datasource-Komponente zeige ich das Ergebnis in einem DBGrid an.

Meine Frage:
Wie kann ich z.B. die komplette dritte Spalte des DBGrids mit einem Faktor multiplizieren? Also dass jedes Feld dieser Spalte z.B. mit 5 multipliziert wird. Das soll lediglich zur Anzeige dienen, die Datenbank darf nicht verändert werden.

Mache ich diese Manipulation direkt im DBGrid, oder besser in der Query-Komponente oder über eine zusätzliche Table-Komponente?

Fragen über Fragen - vielen Dank schonmal für eure Hilfe.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 10:08
Kannst du im Query machen.
Markus Kinzler
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#3

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 10:14
SQL-Code:
select
Spalte1 As LinkeSpalte,
Spalte2 * 5 As Mal5Spalte,
Spalte4 / 4711 As StinktmirSpalte,
Spalte4 As RechteSpalte
form Tabelle
Hinter dem As steht die Bezeichnung, die Du im DBGrid gerne als Spaltentitel sehen möchtest, es sei denn, Du gibst im DBGrid irgend einen Text als Spaltentitel vor. Die Bezeichnung hinter dem As ist gleichzeitig die Bezeichnung, mit der Du per FieldByName auf die Spalte zugreifen kannst.
  Mit Zitat antworten Zitat
Tempdir

Registriert seit: 19. Feb 2009
Ort: Karlsruhe
84 Beiträge
 
RAD-Studio 2009 Pro
 
#4

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 10:31
Klappt PERFEKT !!! Besten Dank für die Hilfe
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.008 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#5

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 11:34
Es gilt hierbei zu unterscheiden, wo die Berechnung durchgeführt wird:
  • Bei einer Anpassung des SQL Statements wird die Berechnung von der Datenbank übernommen und die Werte übertragen.
  • Alternativ kannst du neue Felder in der Query anlegen und die Property Calculated auf True zu setzen.
    Die Berechnung muss dann im Event OnCalcFields der Query durchgeführt werden.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Tempdir

Registriert seit: 19. Feb 2009
Ort: Karlsruhe
84 Beiträge
 
RAD-Studio 2009 Pro
 
#6

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 12:45
Danke @ Stevie für die Hinweise.

Kann ich die Datenbank mittels der Query auch gleich "runden" lassen?

also z.B.:

Delphi-Quellcode:
SELECT (column2 / 3) FROM tabelle;

//Würde wenn column2 z.B. den Wert 10 hätte, das Ergebnis 3,3333333 (Periode) ergeben.
Kann ich irgendwie gleich auf 2 Stellen hinter dem Komma runden?
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#7

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 14:20
Kommt auf die Datenbank an, wenn sie Round kennt, ja.
SELECT Round((column2 / 3),2) FROM tabelle;
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 14:22
Wenn dir dein DBMS eine Funktion dafür bietet.
Markus Kinzler
  Mit Zitat antworten Zitat
Tempdir

Registriert seit: 19. Feb 2009
Ort: Karlsruhe
84 Beiträge
 
RAD-Studio 2009 Pro
 
#9

Re: Daten im DBGrid für Anzeigezwecke manipulieren

  Alt 23. Apr 2009, 14:30
Zitat von nahpets:
Kommt auf die Datenbank an, wenn sie Round kennt, ja.
Sie (TurboDB) kennts zum Glück !!!

Nochmals VIELEN DANK für die Hilfe
  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 03:04 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