AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Tchart Werte aus DB - ohne DBChart

Ein Thema von danieleh · begonnen am 23. Sep 2009 · letzter Beitrag vom 23. Sep 2009
Antwort Antwort
Seite 1 von 2  1 2      
danieleh

Registriert seit: 1. Dez 2005
54 Beiträge
 
#1

Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 11:27
Hallo Alle,

wie kann man am effizientesten Daten aus Datenbank (FB) in ein TChart dynamisch einbringen *ohne* die DBChart zu verwenden ?

Ich möchte die nicht-dbchart Komponente verwenden, da ich die Möglichkeit geben muss, daten aus txt-datei direkt zu importieren (klappt) - optional sollen die Werte von text-datei in datenbank abgelegt werden (klappt) und aus der DB in chart angezeigt.

Es handelt sich um Messwerte die eine zeitlang täglich anfallen (>200 paramenter (columns) x ~90'000 Zeitpunkte (rows)).
Die Serien (Lines) sollen nur auf Abruf (click) einzeln im Chart angezeigt werden.

Tipps und code-beispiele sind sehr willkommen.
Danke
Daniele
(Delphi 2009, TchartPro)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 11:35
Du könntest auch eine Textdatei in ein MemDataSet importieren.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 11:53
Hallo danieleh,

warum willst Du nicht DBChart dafür einsetzen, was spricht dagegen?

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
danieleh

Registriert seit: 1. Dez 2005
54 Beiträge
 
#4

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 12:07
Hallo Markus und Chemiker,

der Zweck der Datenbank ist die Daten beständig zu sichern und besser darauf zugreifen zu können. die notwendigen Schritte dazu klappen schon alle. Nur den letzten Schritt, von der DB zum Chart fehlt noch.

Das Tool soll so flexible sein dass auch Text-dateien und nicht ausschliesslich von DB gelesen werden kann.

Das "Problem" ist das die Text-Datei nicht viel grösser als ein Tag voll Werte sein kann (ca. 200 MB), da sie zu gross wird und ein out-of-memory schmeisst. Also kopiere ich die Daten in eine FB-embedded rein.
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 12:57
Hallo danieleh,

speichere die Messwerte doch direkt in die Datenbank, ohne den Umweg über eine Textdatei zu gehen.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
danieleh

Registriert seit: 1. Dez 2005
54 Beiträge
 
#6

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 13:41
Das System wo die Daten generiert werden, erlaubt nicht dass sie dierekt in DB geschrieben werden können. Dies ist also keine Option.
Ich bekomme die Daten auf Anforderung über ein TCP-stream g-zipped (zB. ein gz ~2.5MB, dann entpackt ~250MB, =Werte für 1 Tag).

Aber die Idee von mkinzler wäre noch zu erwägen.
Wenn man die Daten von der Text-datei direkt lesen will, diese in ein "MemDataSet" laden, dann können sie mit der DBChart angezeigt werden.

Nur: welche Komponente ist dazu empfehlenswert? es gibt die TjvMemoryData, oder die TClientDataSet (was angeblich nicht so toll sein soll - http://www.delphipraxis.net/internal...=tjvmemorydata), oder andere?
  Mit Zitat antworten Zitat
Benutzerbild von TeronG
TeronG

Registriert seit: 19. Jul 2004
Ort: München
960 Beiträge
 
Delphi 2007 Professional
 
#7

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 14:01
Zitat von danieleh:
wie kann man am effizientesten Daten aus Datenbank (FB) in ein TChart dynamisch einbringen *ohne* die DBChart zu verwenden ?
Naja wie währe es mit einem
Pseudocode!!
Delphi-Quellcode:
chart.addSeries... //pro Messpunkt eine Serie hinzufügen. kann auch array of Serien sein!
...

tabelle.first
while not tabelle.eof do
begin
  serien[i].AddXY(tabelle.DateTimewert,tabell1.messpunktwert);
  tabelle.next
end
Oder habe ich da irgendwas übersehen? Kein TTable? (dann mach eins rein! :-p )

Hatte mir mal nen "Schreiber" mit Tchart gebastelt und da klappte das mit dem array of Series & dem addXY recht gut. Der Date-Wert war allerdings meistens NOW -.-" (außer wenn man alte Messwerte geladen hatte^^)
龍 Der Unterschied zwischen Theorie und Praxis ist in der Praxis größer als in der Theorie.
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#8

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 14:18
Du brauchst doch nur FieldByName auszuwerten.

Delphi-Quellcode:
IF NOT StatDS.IsEmpty THEN BEGIN
  wert := StatDS.FieldByName (Feld).value;
  Series.AddXY(i,wert);
END
Gruß
Hansa
  Mit Zitat antworten Zitat
danieleh

Registriert seit: 1. Dez 2005
54 Beiträge
 
#9

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 14:35
Series.AddXY ist warscheinmdlich die einzige lösung, habe aber angst dass bei >500'000 Werte, dies lange dauern kann.

Ich probier mal andersrum, die DBChart zu verwenden und das text-file in ein MemDataSet zu laden.

Danke an Alle
Daniele
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#10

Re: Tchart Werte aus DB - ohne DBChart

  Alt 23. Sep 2009, 14:36
Hallo danieleh,

Zitat von danieleh:
Das System wo die Daten generiert werden, erlaubt nicht dass sie dierekt in DB geschrieben werden können. Dies ist also keine Option.
Ich bekomme die Daten auf Anforderung über ein TCP-stream g-zipped (zB. ein gz ~2.5MB, dann entpackt ~250MB, =Werte für 1 Tag).
Wenn ich das jetzt richtig verstehe, dann werden erst die Messdaten von einem Tag gesammelt und dann als ZIP-Datei übermittelt? Dann werden die Messdaten entpackt und sollen dann in einem TChart angezeigt werden?

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 23:38 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